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ordenador doméstico, ordenador personal, 
microordenador, etc. ya son términos de 
uso común y forman parte de nuestras ex- 
presiones cotidianas. Los ordenadores, 
hasta hace muy poco dominio de pocas 
personas privilegiadas, han conquistado 
actualmente de forma clara su lugar en 
nuestros hogares. Algunos niños los utili- 
zan como juguetes, otros para hacer los deberes escolares, 
mientras que para los adultos resultan un pasatiempo agra- 
dable, aunque cada vez con mayor frecuencia constituyen 
también su instrumento de trabajo. 

Los ordenadores son máquinas y, como tales, realizan 
trabajos. Lo que los distingue claramente del resto es que 
este trabajo no es uno fijo e invariable, sino que se adaptan 
a Cuanto se les solicita; y esto se debe a que los ordenado- 
res son programables. Programar un ordenador significa en- 
señarle qué es lo que queremos que haga. ¿Y si no los pro- 
gramamos? No servirán para nada, se convertirán en unos 
objetos inertes e inútiles. Al comprar un ordenador pode- 
mos creer que hemos adquirido solamente componentes 
electrónicos tales como transistores, resistencias y circuitos 
integrados lo que los especialistas llaman «hardware» (vea 
el volumen 1 de la B. B. 1). Pero no es así, puesto que toma- 
mos también el «software de base», esto es, programas muy 
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Ñ A El Fotografía £ Diversas muestras sde dRienadales personales con pe- 
1 000 riféricos de almacenamiento masivo exterior (arriba) o interior 
(abajo). 
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importantes que hacen funcionar el sistema. Estos progra- 
mas son normalmente, en un ordenador personal, el Intér- 
prete BASIC y otro, a primera vista ininteligible: el Sistema 
Operativo. 

Frecuentemente además del software de base, se pue- 
den obtener otros programas que vienen «escritos» en cin- 
tas magnéticas, en cartuchos electrónicos especiales del ta- 
maño de una caja de cigarrillos o grabados en discos flexi- 
bles. En todos estos casos, no tenemos que hacer nada más 
que encender el ordenador, insertar el programa («cargar- 

lo» como se dice en la jerga) y, luego, ejecutarlo. 
Si hemos cargado un juego, probablemente tengamos 
que demostrar nuestra capacidad para destruir las astrona- 
ves enemigas ayudadas por un pequeño dispositivo de dis- 
paro y control, denominado «joystick», que nos hará sentir 
como pilotos espaciales. Si se trata de un programa didác- 
ticos de matemáticas, podremos repasar algún problema de 
geometría. Si, por el contrario, se trata de un programa de 
tipo profesional, por ejemplo de contabilidad, deberemos in- 


troducir los datos que nos pida y encender la impresora si 
queremos obtener resultados impresos. 

Los ordenadores no ejecutan solamente programas que, 
escritos por otras personas, compremos; por supuesto po- 
demos programarlos nosotros mismos, empleando las reglas 
de programación establecidas por el fabricante. El conjunto 
de estas reglas constituye lo que se denomina lenguaje de 
programación. Se habla de lenguaje porque se emplea para 
«comunicar» al ordenador lo que debe hacer, del mismo 
modo que cuando hablamos a alguien decimos «haz esto 
así». Estas frases son las denominadas «instrucciones». Mu- 
chas instrucciones juntas, ordenadas según un sentido lógi- 
co, constituyen un programa. 


LENGUAJE SECTOR DE APLICACION 
1958 científico-matemático 


- LISP 
de “inteligencia artificial” 


PASCAL 1971 científico y comercial 


científico para aplicaciones 


Cc 1973 aplicaciones industriales 


1979 


para sistemas complejos 


científico y general j 


T ] Fig. 1.—Lenguajes de programación más importantes. 


MODULA-2 
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Los lenguajes de programción nacieron junto con los or- 
denadores. Los más antiguos tienen nombres conocidos, ta- 
les como FORTRAN o COBOL. Otros son muy populares y 
actualmente están al alcance de todos, como es el caso BA- 
SIC, [mientras algunos son sólo conocidos por técnicos o es- 
pecialistas en los campos donde su aplicación resulta ven- 
tajosa (ADA, C...)]. 

Por si desea acudir a él durante la lectura del libro, le 
llamamos la atención sobre el apéndice B, que contiene la 
definición, sintaxis y ejemplos de cada una de las instruc- 
ciones del BASIC que se verán en este volumen de la B.BL. 


ENTRE LINEAS ANDA EL BASIC 


Fundamentos del BASIC 


1 BASIC nació en el año 1964. ¿Sorprendi- 
do? En efecto, suele asociarse su nacimien- 
to con el de los ordenadores personales 
(hace unos diez años), pero en realidad el 
BASIC tiene unos orígenes más lejanos, que 
se remontan casi a la prehistoria de los or- 
denadores. Sus hermanos mayores (FOR- 
TRAN, COBOL y otros) eran lenguajes com- 
plejos que requerían largos períodos de tiempo entre la fase 
de escritura del programa y su ejecución sin errores. Su em- 
pleo estaba reservado a una élite de especialistas que tra- 
bajaban con grandes ordenadores. 

Dos profesores americanos, Kemeny y Kurtz, pensaron 
que, para facilitar el empleo de los ordenadores a estudian- 
tes y profanos, era preciso simplificar bastantes cosas. Su 
ideal era poder sentarse delante del ordenador, programar- 
lo directamente, ejecutar el programa y recibir los resulta- 
dos (.. precisamente lo que hacemos actualmente con los or- 
denadores personales). Kemeny y Kurtz lograron sus pro- 


pósitos y así nació el BASIC, La palabr “a BASIC es la abre- 
viatura de «Beginners All-purpose Symbolic Instruction 
Code» que significa «Lenguaje de programación para prin- 
cipiantes.» 


Es este carácter de «inmediatez», logrado gracias a la 
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Fig. 1.—La traducción del programa al código interno del ordena- 
dor se realiza por medio del Intérprete BASIC. 


acción del Intérprete BASIC, lo que ha otorgado al BASIC la 
inmensa popularidad de que ahora goza. 

Su gran difusión se produjo, sin embargo, (y de ahí los 
equívocos) cuando fue adoptado como lenguaje principal 
por los ordenadores personales. Es evidente que fue un 
«matrimonio» de intereses: se produjo porque ambos, el or- 
denador personal y el BASIC, pretendían las mismas obje- 
tivos: resultar sencillos y fáciles de utilizar. Con toda segu- 
ridad, el BASIC es en la actualidad el lenguaje de progra- 
mación más conocido unviersalmente. 

Como mencionamos antes, uno de los aspectos funda- 
mentales del BASIC «culpable» de su facilidad de uso, es 
que se basa en un Intérprete. Como se observa en la Figura 
1, el Intérprete es un programa particular (escrito en lengua- 
je máquina) que admite como «entradas», además de los da- 
tos, las instrucciones del programa BASIC del usuario, tra- 
duciéndolas a un código «conocido» y admitido por el or- 
denador. Y esto lo hace instrucción a instrucción. Así, aun- 
que en un programa modifiquemos alguna instrucción po- 
demos ejecutarlo sin problemas mientras que en un lengua- 
je como el FORTRAN o el PASCAL cualquier pequeño cam- 
bio (aunque sea tan solo para añadir un «punto» que falta- 
ba) supone someter de nuevo todo el progrma a un proce- 
so, previo a su ejecución, denominando compilación y que 
lleva bastante tiempo. 

Esta es una importante ventaja de los lenguajes «inter- 
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pretados» (como el BASIC) respecto a los «compilados», en 
z n» del programa completo se ha de 


tal cir- 


loz cuales 


de ejecución: el Intérprete tiene que traducir las instruccio- 
nes cada vez que las ejecuta, mientras que con los compi- 
ladores la traducción se hace una sola vez. 

La enorme proliferación del uso del BASIC ha traido 
como consecuencia lógica, el nacimiento de muchos dialec- 
tos, de forma análoga a lo que sucede con las lenguas ha- 
bladas. Cuando a partir de una, original, nacen muchas va- 
riantes de una misma lengua, pueden llegar a producir con- 
fusiones en su aprendizaje. Así sucedió también en el caso 
del BASIC. Las principales y más importantes instrucciones 
se mantienen iguales de una versión a otra, pero como cada 
fabricante ha añadido a su ordenador peculiaridades intrín- 
secas a su marca, resulta prácticamente imposible que un 
programa escrito para un ordenador concreto pueda ejecu- 
tarse directamente en otro: una coma colocada en diferente 
lugar o suprimida basta para que la máquina se niegue a 
«acatar» y ejecutar un programa. Así pues, es imaginable lo 
que puede suceder si cada ordenador modifica las reglas 
de las instrucciones BASIC. 

En contra de esta tendencia «dispersora» ha surgido con 
fuerza en los últimos años un deseo de «normalización», que 
se está viendo materializado con los equipos MSX, Sin em- 
bargo, este nuevo estándar no ha sido todavía universal- 
mente reconocido. Por tanto hoy en día hablar de BASIC, en 
general, quiere decir describir la estructura del lenguaje, sus 
instrucciones principales, los conceptos comunes a todos 
los dialectos y advertir cuando existan divergencias impor- 
tantes. 

Para adaptar después un programa en BASIC: a un or- 
denador específico, se necesita tener la paciencia de amol- 
darlo a algunas de sus instrucciones particulares. Nosotros, 
en este volumen de la B. B. 1, hablaremos del BASIC en los 
términos más generales posi 
obstante, que las principales 


versiones del BAS 


tru 


Oe 


vos, las cuales se presentarán en un próximo libro (segun- 
do de los dedicados específicamente al BASIC) 
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El primer programa 


Hay dos modos de aprender un lenguaje de programa- 
ción: estudiar detenidamente todas sus reglas desde la pri- 
mera a la última y luego, tratar de escribir los primeros pro- 
gramas;, o bien, quizá más pragmáticamente, tratar de escri- 
bir inmediatamente programas sencillos y aprender las re- 
glas poco a poco. Nosotros adoptaremos este segundo mé- 
todo que, en nuestra opinión, es menos pesado y más eficaz. 
Veamos un programa en BASIC de lo más facilón: 


10 INPUT A 
20 INPUT B 
30 INPUT C 
40 PRINT A 
50 PRINT B 
60 PRINT C 


¿Qué observamos? 


El programa está escrito en varias líneas. Cada línea se 
inicia con un número que va aumentando de forma sucesi- 
va. Hay también palabras inglesas, como INPUT y PRINT, y 
letras (A, B, C). Lo que no vemos, pero tiene una enorme im- 
portancia, es que cada línea se finaliza pulsando una tecla 
especial, que equivale a la que en las máquinas de escribir 
produce el retroceso del carro (en inglés, «Carriage Re- 
turn»). 

Cada línea de cualquier programa debe terminar siem 

e con la pulsación de esta tecla. Según los ordenadores 
se llama de «RETURN » «ENTER » «CR..». Cuando se utiliza 
un nuevo ordenador, esta es la primera tecla que se debe 
localizar, 

¿Qué hace este sencillo programa? En las líneas 10,20 
y 30 encontramos escrita la palabra INPUT seguida por una 
letra. INPUT es una instrucción del lenguaje BASIC e indica 
al ordenador que solicite la entrada de datos. ; 

Las letras A, B y C son tres nombres cualesquiera de va- 
riables numéricas, iguales que las que aprendemos a mane- 
jar en la escuela. Cuando el programa se ejecuta, el orde- - 
nador solicita tres veces seguidas un número, imprimiendo 
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DST : 
OS IS IAN NN 


PAL Ys 


NJ] Potografía 1.—En estos teclados se pueden ver las teclas de Enter y 
Return, que realizan la función “Retorno de carro”. 


cada vez un signo de interrogación y quedando parado has- 
ta que no introduzcamos (terminando con un «RETURN») adi- 
cho número por el teclado. El primer valor que metamos se 
asignará a (se depositará dentro de) la variable A, el segun- 
do a la B y el tercero a la C. Más adelante profundizaremos 
en el concepto de variable y sus tipos; de momento, lo im- 
portante es entender que mediante la instrucción INPUT se 


pueden comunicar datos al ordenador y asociarlos a varia- 
bles. 


Continuemos con el examen del programa 


En las líneas 40, 50 y 60 encontramos otra instrucción 
BASIC: PRINT. PRINT significa literalmente «imprimir» pero, 
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por extensión se refiere a la presentación visual en pantalla. 
Desempeña por tanto la función opuesta a INPUT, puesto 
que saca los datos fuera del ordenador, presentándoselos al 
usuario. 

PRINT conduce los datos a la pantalla del ordenador: 
otras instrucciones de salida (que veremos en posteriores 
capítulos) llevan los datos a la impresora, a la cinta de ca- 
sete, o a discos flexibles. Al ejecutar el programa, después 
de haber tecleado los tres datos como respuesta a los sig- 
nos de interrogación que nos presenta el ordenador vere- 
mos aparecer en la pantalla los valores asignados a cada va- 
riable. El proceso sería: 


RUN 

212 Pide valor de A. 
223 Pide valor de B. 
234 Pide valor de C. 


12 Presenta valor asignado a la variable A. 
23 Presenta valor asignado a la variable B. 
34 Presenta valor asignado a la variable C. 


RUN es la instrucción del lenguaje BASIC em pleada 
para ejecutar un programa. De eclear la tal tual, sin 
mngún número de línea delante, pues no es una instrucción 
del programa. 

Demos un paso más y veamos cómo puede mejorarse 
nuestro primer programa en BASIC. En lugar de repetir tan- 
tas veces, en varias líneas, la instrucción INPUT para recibir 
datos, se pueden indicar las variables una después de otra 
en una sola línea de INPUT. Así el programa anterior lo po- 


dríamos escribir: 


10 INPUT A, B, C. 
40 PRINT A. 
50 PRINT B. 
60 PRINT C. 


Este programa es perfectamente equivalente al prime- 
ro, INPUT es una instrucción que puede actuar sobre cual- 
(uier grupo de variables colocadas una después de otra 
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También la instrucción PRINT se comporta del mismo 
modo. En lugar de repetirla tres veces, en las líneas 40, 50 
y 60, se puede escribir en una sola. 


10 INPUT A, B, C, 
40 PRINT A, B, C. 


No obstante, si ejecutamos los dos programas observa- 
remos una cierta diferencia. En el primer caso, los tres datos 
aparecen en la pantalla en columna, como vimos antes, 
mientras que ahora aparecerán en la misma línea, algo se- 
parados entre sí. Es decir: 


RUN 

212 

223 

234 

12 23 24 


Si en lugar de emplear comas para separar las varia- 
bles A, B y C en la instrucción PRINT hubiésemos utilizado 
punto y coma, habríamos obtenido los datos sin separación 
alguna. 

Estas peculiaridades de la instrucción PRINT pueden 
parecer enojosas, pero son las que, si se utilizan bien, nos 
permitirán hacer agradable y eficiente la presentación vi- 
sual de los datos de un programa. Con demasiada frecuen- 
cía, nos encotramos programas muy complejos y llenos de 
buenas ideas, pero con una deficiente presentación visual 
de los resultados en la pantalla, 


Como numerar las líneas 

Un programa está constituido por una sucesión de lí- 
neas (líneas escritas), cada una de las cuales contiene una 
o más «órdenes», que se conocen como instrucciones. Cada 


lenguaje tiene sus propias instrucciones. Las instrucciones 
de un lenguaje no son nunca las mismas que las de otro, 
por lo que es fácil reconocer en cuál se ha escrito un pro- 
grama observando las instrucciones particulares que utiliza. 

Cuando veamos el listado (relación con el contenido de 
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MJ) Fotografía 2.—Listado de un programado BASIC tal como aparece 
¡E por pantalla o impresora, 


todas las líneas del programa) de cualquier programa, ob- 
tendremos la impresión de que está escrito en inglés. La- 
mentablemente, sobre esta cuestión no hay nada que hacer. 
Todo el mundo técnico, científico y de negocios, ha adap- 
tado ya este idioma, por lo que cuando surje un nuevo len- 
guaje de programación utiliza siempre palábras inglesas, 
consideradas más «internacionales» que las demás. Como 
confirmación de tal circunstancia basta recordar que uno de 
los más recientes lenguajes de programación, el PASCAL, 
fue desarrollado en Suiza pero utiliza términos ingleses. 

Un programa escrito en BASIC se reconoce inmediata- 
mente por la especial característica de tener todas sus lí- 
neas numeradas. El incrementar los números de línea de 10 
en 10, como haremos normalmente en nuestros ejemplos, es 
sólo por una cuestión práctica: dejar espacio para la inser- 
ción de nuevas instrucciones con un número de línea inter- 
medio entre los de dos instrucciones ya introducidas. Aun- 
que no lo parezca esta medida puede evitarnos muchos dis- 
gustos, especialmente en las versiones del BASIC que no ad- 
miten la «renumeración» de las líneas. 

Numerar las líneas de un programa en BASIC es muy 
sencillo: escribir a mien le la línea ur nero 7 
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entero, es decir, un número sin coma ni parte decimal, y !e- 
ner en cuenta algunas reglas: 


O Dos líneas no pueden tener el mismo número. En caso 
contrario el ordenador «recuerda» solamente la que se 
escribió en último lugar y olvida la anterior. 

O Una línea no puede estar constituida solamente por el nú- 

mero, sino que debe contener una instrucción efectiva 
por lo menos. Si escribe solamente el número, el ordena- 
dor ignorará esa línea. 

O Para borrar (anular) una línea basta volver a escribir su 
número y nada md El ordenador sustituirá entonces la 
línea antigua por la nueva (primera regla), vacía y, por 
consiguiente la anula (segunda regla). 

O El número de línea puede ser cualquier número entero 
positivo, el cero (0) no se útiliza casi nunca y el número 
máximo es una característica del propio ordenador con- 
creto que utilicemos. Para saber cuál es su valor debe- 
remos consultar el manual correspondiente del aparato. 
En cualquier caso suele ser muy alto y, por ello, suficien- 
te para escribir los programas. Si, por ejemplo, este nú- 
mero fuera 32767, significaría que se podrían escribir 
32.768 líneas de programa (contando la número 0). 

O Las líneas de un programa representan una secuencia ló- 
gica de órdenes impartidas al ordenador y, por este mo- 
tivo, la numeración de las líneas debe tener la misma pro- 
gresión lógica. Los números de línea no deben ser nece- 
sariamente correlativos, como lo son «23, 24, 25, 26..», sino 
solamente respetar el orden adecuado. El ordenador lee- 
rá las instrucciones en orden ascendente (desde el me- 
nor al mayor número de línea usado). 


Con referencia al Intérprete debemos insistir en que 
para incorporar cualquier línea al programa, las instruccio- 
nes de que conste deberán ir precedidas por el número de 
línea. Al hacer esto evitamos que se interpreten las instruc- 
ciones como de «inmediata» ejecución, bloquándose esta 
hasta que demos el comando RUN, momento en el cual en- 
trará en acción el Intérprete para «traducir» todas las veces 
que sean necesarias las instrucciones. . 

Si, por el contrario, no tecleamos los números de línea, 
la ejecución del comando individual será inmediata (siem- 
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pre a cargo del Intérprete). Precisamente por eso, cuando 
deseamos usar las funciones del sistema, tales como LIST 
(para proporcionar el listado de las instrucciones del pro- 
grama actualmente en memoria), LOAD y SAVE (para car- 
gar/grabar un programa desde/en un soporte magnético), 
RUN (ya visto), etc., no les anteponemos un número de línea. 

Si deseamos escribir un programa que ejecute conse- 
cutivamente tres instrucciones (primera, segunda y terce- 
ra) la redacción 


30 Primera instrucción. 
45 Segunda instrucción. 
120 Tercera instrucción. 


Es correcta y, en cambio, no lo sería: 


30 Segunda instrucción. 
45 Primera instrucción. 
120 Tercera instrucción. 


Porque el ordenador ejecutará primero la instrucción 
de número más bajo, es decir la 30, que queremos se eje- 
cute en segundo lugar. 


O Cuando escribimos un programa, es decir, cuando lo in- 
troducimos a través del teclado del ordenador, pode mos 
escribir primero una línea con un número más alto y lue 


go otra con número más bajo, es decir, no hace falta in- 
troducir las líneas por el orden de sus respectivos núme- 
ros de línea. 


La explicación de lo anterior es muy simple: el ordena- 
dor ordena las líneas de forma automática. Por consiguien- 
te, se puede escribir un programa de este modo: 


60 Tercera instrucción. 
40 Segunda instrucción. 
20 Primera instrucción. 


Porque el aparato las ordenará de forma automátic 
como sigue: 


20 Primera instrucción. 
40 Segunda instrucción. 
60 Tercera instrucción. 
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O Si en cualquier momento comprobamos que hemos olvi- 
dado una instrucción, podemos introducirla sin ningún 
problema asignándola el número de línea adecuado. 


Supongamos, por ejemplo, que hubiéramos escrito el 
programa numerando las líneas de 10 en 10, como es reco- 
mendable hacer. Si en ese momento nos percatáramos de 
que se nos ha olvidado una (o más) podríamos teclear la 
nueva línea con un número intermedio. Por ejemplo, si hu- 
biéramos escrito: 


10 Primera instrucción. 
20 Segunda instrucción, 
30 Tercera instrucción. 
40 Cuarta instrucción. 


Y quisiéramos introducir una instrucción entre la terce- 
ra y la cuarta, nos bastaría teclear: 


35 Nueva instrucción/tercera bis. 


El ordenador la pondrá automáticamente en orden 
como sigue: 


10 Primera instrucción. 

20 Segunda instrucción. 

30 Tercera instrucción. 

35 Nueva instrucción/tercera bis. 
40 Cuarta instrucción. 
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BLOQUES Y VARIABLES: 
DEFINIENDO UN PROGRAMA 


n ordenador es una máquina que, por sí 
sola, no sabe realizar ninguna acción; nece- 
sita un programa que la transforme en una 
máquina viva. Para comunicar al ordenador 
este programa es necesario utilizar un len- 
guaje, un «lenguaje de programación». El 
BASIC es uno de los más importantes por- 
MO que es muy fácil de aprender y por haber 
sido adoptado por todos los ordenadores personales. 
Insistimos en que la base de todo sigue siendo el he- 
cho de que el ordenador no inventa nada y de que el pro- 
grama debe ser concebido y escrito por nosotros, los usua- 
rios. Si no sabemos cómo resolver un problema, no pode- 
mos pretender que el ordenador lo resuelva por sí solo. 
Ántes de programar un ordenador debemos tener las 
ideas muy claras y saber con exactitud qué queremos pe- 
dir a la máquina y cómo hacer que esta pueda ofrecérnoslo. 
Si, por ejemplo, un programador experto en leyes tribu- 
tarias describe con «pelos y señales» a un ordenador cómo 
completar los calculados del modelo 740 (es decir, introdu- 
ce programa para realizar todas las operaciones correspon- 
dientes), ya no tendrá necesidad de repetir las cuentas a 
mano para cada formulario: una vez introducidos los datos, 
el ordenado de todo. 


: decir «expli 


¡QUe 


dad alguna, la forma en que precisa comportarse en todas 
las posibles situaciones que se puedan presentar durante el 
trabajo; en otras palabras: definir un algortimo (en el ejem- 
plo anterior para rellenar el modelo 740). 

Solamente después de haber definido un algoritmo que 
tenga en cuenta todos los casos posibles, se podrá «tradu- 
cir» éste al lenguaje BASIC y escribirlo en el ordenador. 

Aunque le «suene a chino» eso de los algoritmos, cono- 
cemos muchos y los utilizamos cada día sin reconocerlos 
como tales. Son algoritmos las reglas aprendidas en la es- 
cuela para efectuar las sumas o las divisiones, el procedi- 
miento que seguimos para arrancar el automóvil ¡e incluso 
el método que empleamos para hacer café! 


Los algoritmos 


La palabra algoritmo se deriva del nombre del matemá- 
tico y astrónomo áraba Mohammed al-Khuwarizmi, que vi- 
vió antes del año 850, 

Entre sus diversas obras estaba una profunda y com- 
pleta recopilación de los sistemas de numeración entonces 
utilizados en la India. El sistema indio, que representa a los 
números en forma posicional, fue evolucionando hasta con- 
vertirse en nuestro sistema de numeración actual. Las cifras 
0, 1, 2, 3 etc., que llamamos «arábigas» para distinguirlas de 
las romanas (1, V, X, C etc), son en realidad de origen indio. 
Este error «histórico» se debe al hecho de que cuando las 
obras de Mohammed al-Khuwarizmi fueron traducidas al la- 
tín se creyó que todo era árabe como el texto, incluido el 
sistema de numeración presentado, que fue denominado 
«algorismo», término del cual se derivó posteriormente al- 
goritmo. 

Gracias, pues, a este matemático árabe, podemos reali- 
zar actualmente la mayor parte de las operaciones aritmé- 
ticas con números. 

La palabra «algoritmo» acabó por significar cualquier 
conjunto de reglas, primero para un cálculo matemático' y 
luego para un problema cualquiera 

A propósito de Mohammed al-Khuwarizmi, le somos 
deudores no solamente de los números «arábigos», sino tam- 
bién de las bases de una rama fundamental de las matemá- 
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a Fotografía 1.—Antes de “teclear” en el ordenador un programa es 
conveniente realizar un estudio previo del mismo que evite impro- 
visaciones y Sorpresas. 


ticas, que conocemos como álgebra. La palabra «álgebra» 
se deriva del título de la obra más importante de Moham- 
med al-Khuwarizmi: «Al-jabr wá Imugabalh» (y no es broma), 
Del término «al-jabr» se deriva precisamente la palabra «ál- 
gebra». 

Cuando deseamos escribir un programa en BASIC que 
nos resuelva un problema, no es conveniente sentarse in- 
mediatamente delante del teclado y comenzar a introducir 
las sentencias (o líneas del programa). Los modernos orde- 
nadores ni son tan cómodos de utilizar y tan atrac- 
tivos en su interactividad (diálogo del «tipo pregunta-res- 
puesta») que sa inducir a cometer este error con faci- 
lidad. 

¿Qué sucede cuando se escribe un programa «de gol- 
pe y porrazo» sin ponerse primero a considerar a fondo to- 
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dos los aspectos del problema? Al principio, todo parece fá- 
cil. Luego, se descubre que el programa presenta proble- 
mas en alguna situación que no estaba prevista. Esto no tie- 
ne «nada de malo», puesto que bastará una pequeña correc- 
ción, pero esta última, a su vez, puede hacer surgir un inco- 
veniente en otro caso: tendremos que realizar otro pequeño 
retoque y así sucesivamente... 

Cuando al final de todo el proceso anterior el programa 
funcione a la perfección (si es que lo hace), descubriremos 
haber empleado mucho más tiempo del que hubiera sido 
necesario, partiendo de un estudio «serio» del problema, an- 
tes de comenzar a escribirlo. Pero este no es el único inco- 
veniente; hay otros mucho más graves: 


O No tendremos la certeza del funcionamiento correcto en 
cualquier condición. 

O Será difícil comprender cómo funciona el programa, par- 
ticularmente después de transcurrido algún tiempo des- 
de la escritura, pues los sucesivos cambios habrán des- 
hecho una posible estructura inicial. 

O En consecuencia, es también más difícil modificarlo en 
caso de necesidad. 

O El programa será «más o menos» comprensible solamen- 
te para el autor, imposibilitando su fácil intercambio. 


Para evitar todo lo anterior basta introducir algún co- 
mentario (con la instrucción REM que ya veremos) en el pro- 
pio programa. El lenguaje BASIC no es fácilmente legible ni 
comprensible, y resulta complicado cuando menos enten- 
der las intenciones del programador, a partir de la simple 
lectura de las instrucciones del pagana. 


Es, pues, nece sano que mamada 


má clara la estru 


omo su tauncionamiento en al lc ter cond ) 
¿Cómo se puede nar esto a la práctica: 
Escribiendo un algoritmo que describa por completo el 
programa. Al realizar este algoritmo, antes de ponernos con 
la escritura del programa, se obtienen las notables ventajas 
siguientes: 


O Los problemas se abordan con la lógica normal y se des- 
criben en nuestro idioma, y no en BASIC (siempre más 
«lejano» a nosotros). 
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O La escritura del programa se convierte parácticamente 
en una traducción del algoritmo al BASIC. 

O El funcionamiento del programa es perfectamente com- 
prensible incluso para otras personas. 

O Es mucho más fácil estudiar eventuales modificaciones 
en el algoritmo e insertarlas, luego, en el programa. 


Conviene, pues, antes de iniciar la escritura de un pro- 
grama, desarrollar el algoritmo resolutivo del problema. 


Diagramas de flujo 


Un algoritmo, escrito con palabras, presenta un incon- 
veniente: la dificultad de seguir el flujo lógico del programa 
(es decir, el recorrido). Dicho de otro modo, no es fácil ha- 
cerse una idea global para determinar de un vistazo qué ins- 
trucciones se ejecutan y cúales no, qué hacen y sobre la 
base de qué condiciones. 


Para resolver este prob lema se han desarrollado varias 
técnicas. La más adaptada al BASIC es un aos gráfica 
denominada de diagramas de bloques o diagramas de flujo 


(Mowcnart) 

En las Figuras 1 y 2 se indican los símbolos más impor- 
tantes de los que hace uso. En la primera se presentan los 
que sirven para ilustrar los programas (y los algoritmos), 
mientras que la Figura 2 comprende los símbolos utilizados 
para referirse a los soportes físicos de los datos y a las uni- 
dades periféricas de entrada/salida (E/5S). : 

En un diagrama de flujo aparecen muchos de estos sím- 
bolos (presentados en forma de rectángulos, rombos y otras 
figuras geométricas) unidos mediante líneas. Las líneas in- 

dican la conexión lógica entre una operación y la sucesiva, 
Los call (las figuras geométricas) representan los diver- 
sos tipos de instrucciones ejecutables. Dentro de cada blo- 
que se describen la operación u operaciones que simboliza. 

Veamos inmediatamente un ejemplo. En la Figura 3 se 
muestra el diagrama de bloques correspondiente al algorit- 
mo «Cómo hacerse un café» que describimos con los pasos 
siguientes: 


1) Coger la cafetera. 
2) Coger el bote del café. 
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Bloque Significado 


Comienzo del diagrama de flujo 


Final del diagrama 


Operación de entrada o 
salida de datos 


Operación de proceso 
de datos 


Operación de bifurcación, 
elección o decisión 


Salto a una subrutina 


Reenvío a un diagrama 
de bloques separado 


Llamada desde otro 
diagrama de bloques 


<o 0-2 0-00 


MEN Fig. 1.—Símbolos de los diagramas de fujo. 


” 


PARA 


Bloque Significado 


Salida de datos a 
impresora 


Pantalla o teclado 


Unidad de disco 


Unidad de cinta magnética 


Unidad de tarjetas perforadas 


se 
A 
dl 
Q 
-. 


Y Fig. 2—Algunos símbolos de los diagramas de flujo utilizados para 


Y indicar las unidades periféricas. 
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1) Pg 3. Diagrama de bloques del programa “Cómo hacerse un café”. 
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3) Si el café está molido, saltar el resto de esta instruc- 
ción y proseguir con la instrucción 4. Si no lo está, molerlo 
(y, una vez molido, pasar al punto 4). 

4) Llenar de agua la parte baja de la cafetera. 

5) Llenar de café molido la cazoleta correspondiente. 

6) Cerrar la cafetera. 

7) Ponerla sobre el fuego de la cocina. 

8) Encender el gas. 

9) Comprobar si el café ha salido en su totalidad; si no 
fuera así, esperar hasta que ocurra. 

10) Apagar el gas. 

11) Final: el café está listo para servir. 


Un diagrama de flujo se lee a partir del círculo que in- 
dica el comienzo del algoritmo (en los diagramas de flujo 
utilizaremos por comodidad una «pseudoelipse» en su lu- 
gar) y siguiendo las líneas, que representan la secuencia ló- 
gica en la que se ejecutarán las operaciones. Las líneas se 
recorrerán desde arriba hacia abajo y desde la izquierda a 
la derecha, salvo si existe una flecha en sentido contrario. 

Partamos, pues, de la pseudoelipse inicial (en la parte 
superior) y sigamos la línea que desciende. Encontraremos 
un rectángulo correspondiente al punto 1 del algoritmo. 

Un rectángulo significa: ejecutar la operación descrita 
(un proceso o cálculo cualquiera) y, luego, proseguir a lo lar- 
go de la línea. 

Proseguimos, pues, y encontramos otro rectángulo 
(punto 2). Ejecutamos también esta operación y continua- 
mos, encontrándonos, esta vez con un símbolo diferente: un 
rombo. 

un To 


A) y, a | 


lea de a. El camino a , seguir será el correspondiente a 
la decisión tomada. Nuestro rombo corresponde al punto 3 
de este programa: ¿está molido el café? Sigamos la línea co- 
rrespondiente a cada respuesta. Si la respuesta es afirmati- 
va (Sl), pasamos al punto 4, y si la respuesta en negativa 
(NO) pasaremos al rectángulo de «moler el café», después 
de lo cual la línea se encuentra nuevamente con la que co- 
rresponde a la respuesta afirmativa, lo que indica, de forma 
gráfica, que después de este pequeño bucle llegamos tam- 
bién al punto 4. 
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Lo que acabamos de ver es, en definitiva, un ejemplo 
de ejecución condicional de una instrucción: el café se mue- 
le si, solamente si, la respuesta a la pregunta anterior (¿está 
molido ya?) era NO. 

Resulta fácil, en este punto, comprobar cómo el resto 
del diagrama corresponde, punto por punto, al algoritmo del 
café, hasta su conclusión, simbolizada, como el principio, por 
el dibujo de una pseudoelipse. 

En el punto 9 (un rombo y, por consiguiente, una elec- 
ción) se nos pregunta si el café ha salido en su totalidad. Si 
la respuesta es afirmativa (Sl), proseguirá el diagrama (y el 
programa) mientras que de no ser así, una línea nos hace 
retornar al comienzo del propio punto, esperando que se 
cumpla la condicción de salida. Una estructura de este tipo 
se denomina bucle de espera, por cuanto se mantiene a la 
espera de que sea cierta una condición antes de proseguir. 


Símbolos fundamentales de los diagramas de flujo 


Volvamos a la Figura 1, en la que habíamos indicado 
los símbolos principales de los diagramas, según uno de los 
sistemas más utulizados. Lamentablemente, no existe una 
normalización, es decir, un sistema universalmente acepta- 
do. 

El bloque fundamental es el rectángulo, que indica una 
acción (un proceso o un tratamiento) a desarrollar. Por ejem- 
plo, multiplicar dos números o determinar el menor entre 
una serie de valores. Con referencia a una posible clasifica- 
ción de las instrucciones que veremos más adelante, el rec- 


tángulo se emplea para las instrucciones declarativas y para 
las ejecutivas de cálculo O 
Una variante d ES »s ba 


rras verticsa 
dicar la llamac qt 
sarrolla una di area y que, al ac: abarla, vuelve al 
punto desde el cual se la llamó) de aubrufina se describiría, 
a su vez, con un diagrama de bloques separado. . 

El rombo indica una elección entre dos (o más raramen- 
te, tres) salidas. Se suele plantear una pregunta (condición) 
y si la respuesta es afirmativa (SI) el programa prosigue por 
una parte y si la respuesta es negativa (NO), proseguirá por 
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lA otra. Este símbolo a a 61 cciones de salto 
ndicional o de ejecución c: cional 

El paralelogramo indica una operación genérica de en- 
trada o salida de datos (E/S). En diagramas de otro tipo se 
utilizan Símbolos diferentes según el dispositivo periférico 
empleado (lector de fichas, unidad de disco, de cinta, etc.). 
Los símbolos empleados en este caso (Figura 2) recuerdan, 
de una manera estilizada, el periférico que representan. En 
los diagramas de bloques que representan programas se 
emplea siempre un mismo símbolo porque se hace referen- 
cia a la instrucción de E/S más que a la propia máquina. Uti- 
lizaremos el paralelogramo para indicar todas las operacio- 
nes de entrada y de salida. 

Para pre el comienzo ó el final de un algoritmo se 
emplean círculos (o pseudoelipses) con las palabras «Co- 
mienzo» y «Fino (o bli en inglés, «Start» y «End»). 


Las variables 


En los primeros ejemplos de programas que vimos an- 
teriormente, encontramos ya variables. Las variables son 
como una especie de cajas en las que se introducen los da- 
tos sobre los que trabaja el programa. Desde el punto de vis- 
ta físico, dichas cajas son celdillas, o grupos de celdillas, de 
la memoria central del ordenador. 

El concepto de variable de los lenguajes de programa- 
ción no es muy diferente del aprendido en la ee du- 
rante las lecciones de matemáticas. Ora 1 variable es un nom- 
bre simbólico usado para indicar una magnitud a la. e se 
puede asignar un valor efectivo 

Un sencillo ejemplo puede aclarar algunas dudas. Su- 
pongamos que tenemos que rellenar un impreso, o formu- 
lario, para la solicitud de un certificado. Casi todos estos im- 
presos comienzan pidiendo los datos de filiación tales como: 
apellidos, nombre, año de nacimiento, etc. Junto a cada uno 
de estos datos hay una casilla en la que tenemos que es- 
cribir nuestros datos personales: 


ADOOS conri Zorrilla Vizcaino 
NOM in Ignacio 
Año de nacimiemo mnaccacanonconeinmeneniniss 1974 
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«Apellidos,» «Nombre» y «Año de nacimiento» serían va- 
riables del impreso a las que se atribuirán valores efectivos 
en nuestro caso, Zorrilla Vizcaino, Ignacio y 1974. Todos los 
impresos llevan indicadas las mismas variables, a las que 
cada uno «asigna» sus propios datos. En el lenguaje BASIC, 
estas variables podrían llamarse: APELLIDO $ NOMBRES y 
AÑO. 

El signo del dólar ($) que hemos colocado al final de 
las dos primeras variables indica en BASIC que se trata de 
«variables alfanuméricas» (o de cadena de caracteres). La 
falta de este signo ( ANO) indica que se trata de una varia- 
ble numérica. 

Las variables aprendidas en la escuela se referían sola- 
mente a números, mientras que las que utilizamos en los or- 
denadores tales como APELLIDOS y NOMBRE$, representan 
un concepto más amplio. 


L 1 lamente algu 
NE tales como unir dos cadenas, fraccionar 
una O inelule una cadena más corta en otra más larga. 
En la figura 4 podemos ver variables de ambos tipos y 
sus distintos contenidos (o valores): en el caso de las numé- 


II Fig. 4 —Variables numéricas y alfanuméricas (o de cadena). 


1 
' 


ricas un número (A=27) y en el de los alfanuméricas una ca- 
dena de caracteres (A$=CASA). 

Los nombres de las variables pueden elegirse de for- 
ma arbitratria en un programa, pero tienen que satisfacer al- 
gunas reglas precisas. La regla más importante se refiere al 
carácter inicial, que debe ser siempre una letra del alfabeto 
(de la A a la Z), mientras que los demás caracteres pueden 
ser tanto letras como cifras o incluso algunos caracteres es- 
peciales como el $, con el que debe acabar el nombre de 
cualquier variable alfanumérica. 

Veamos algunos ejemplos: 


A 

AL 
PIPPO 
W345 


Se trata de cuatro nombres correctos de variables (por- 
que comienzan con una letra). Los dos nombres, PIPPO y 
W345, pueden parecer demasiado largos pero, en realidad, 
algunos ordenadores admiten nombres con una longitud de 
hasta 40 caracteres. 

En el lenguaje BASIC, las variables pueden ser de di- 
verso tipo según la magnitud que representan. El tipo de va- 
riable se suele reconocer añadiendo un carácter especial 
como sufijo al final del nombre de la variable. El sufijo más 
importante es el signo del dólar ($) que identifica a las va- 
riables alfanuméricas. Por ejemplo: 


B$ 
MARIPOSAS 
D2$ 


Se trata de tres nombres de variables de cadena que 
se reconocen inmediatamente por la presencia del signo del 
dólar ($). Su lectura sería: B-dólar, MARIPOSA-dólar y D2-dó- 
lar. 

También las variables numéricas se distinguen en di- 
versos tipos según la clase de número que representan: 


O Las variables enteras contienen números enteros, sin par- 
te fraccionaria o decimal, comprendidos entre —32768 y 
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32767. Algunos ordenadores utilizan el carácter del % 
para Inprssantar a estas variables (como A% o B2%). 

O | eales de simple precisión, es decir, las que 
¿pel coma (128949, 57). Son las variables más comunes 
y no hace falta ningún sufijo para distinguirlas aunque se 
puede emplear el carácter del signo de exclamación ('). 
O números con seis o nueve alas significativas. 

O Las variables reales de doble pr ) ' (utilizadas sola- 
mente por le ordenadores Reale: más grandes) 
pueden «trabajar» con números de 14 cifras y son iden- 
tificables por el sufijo denominado, en la jerga, «cancela» 
(o sostenido en las aplicaciones de audio): + 


Aunque los símbolos %, ! y + se usan, efectivamente, 
para determinar el tipo de la variable hay algunos ordena- 
dores (los MSX, el Spectravideo o el IBM-PC) que dan al 
usuario la posibilidad de definir como pertenecientes a una 
de las 3 clases todas las variables cuyo nombre comience 
por una letra determinada. Por ejemplo: 

10 DEFINIT EN define de tipo entero todas las variables 
que comiencen por cualquier letra entre la 1 y la N. 

Las equivalentes de simple y doble precisión son: 
DEFSMG y DEFDBL respectivamente. 
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INSTRUCCIONES DE ENTRADA, DE SALIDA Y 
DECLARATIVAS (LOS ARRAYS) 


Las palabras reservadas 


ada lenguaje de programación está consti- 
tuido por un conjunto bien determinado de 
instrucciones, tales como en BASIC: PRINT, 
GOTO, READ, INPUT o REM. Si se consulta 
un manual de BASIC de los que suministran 
con los ordenadores, nos percataremos in- 
7 DN mediatamente de que las instrucciones son 
AE varias decenas y, a veces, superan incluso 
el centenar. No podemos indicar cuántas son con exactitud 
porque su número varía de un ordenador a otro según el 
dialecto de BASIC utilizado. 

En la Figura 1 hemos indicado las "palabras reservadas” 
del ordenador IBM PC, pero cada ordenador tiene las suyas 


propias. Estas palabras reservadas son aq uellas a las que el 
ordenador atribuye un significado particular; en la práctica, 
a cada una de ellas corresponde una instrucción en BASIC. 
El ordenador IBM PC tiene 160 palabras reservadas, algu- 
nas de las cuales son comunes a muchos a otros ordenado- 
res. Hablar de BASIC, en general, supone referirse, precisa- 
mente, a este conjunto “central” de instrucciones. 

Reducido, pues, al máximo el campo de tratamiento de 
las instrucciones del lenguaje BASIC, resulta fácil observar 
cómo se pueden clasificar en varios grupos, cada uno de 
los cuales desarrolla una función particular. 
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ABS EOF LPRINT RIGHTS 
AND EQU LSET RND 
ASC ERASE MERGE RSET 
ATN ERL MIDS RUN 
AUTO ERR MKDS SAVE 
BEEP ERROR MKIS SCREEN 
BLOAD EXP MKSS SGN 
BSAVE FIELD MOD SIN 
CALL FILES MOTOR SOUND 
CDBL FIX NAME SPACES 
CHAIN FNxxxXXXXXX NEW SPCÍ( 
CHRS$ FOR NEXT SQR 
CINT FRE NOT STEP 
CIRCLE GET OCTS STICK 
CLEAR GOSUB OFF STOP 
CLOSE GOTO ON STRS 
CLS HEXS OPEN STRIG 
COLOR IF OPTION STRINGS 
COM IMP OR SWAP 
COMMON INKEYS OUT SYSTEM 
CONT INP PAINT TAB( 
cos INPUT PEEK TAN 
CSNG INPUTH PEN THEN 
CSRLIN INPUTS PLAY TIMES 
CvD INSTR POINT TO 

cv! INT POKE TROFF 
cvs KEY POS TRON 
DATA KILL PRESET USING 
DATES LEFTS PRINT USR 
DEF LEN PRINTH VAL 
DEFDBL LET PSET VARPTR 
DEFINT LINE PuT VARPTRS 
DEFSNG LIST RANDOM] ZE WAIT 
DEFSTR LLIST READ WEND 
DELETE LOAD REM WHILE 
DIM Loc RENUM WIDTH 
DRAW LOCATE RESET WRITE 
EDIT LOF RESTORE WRITES 
ELSE LOG RESUME XOR 
END LPOS RETURN 


ME Fig. 1.—Las 160 “palabras reservadas” del ordenador IBM PC. Cada 
una de ellas constituye, en la práctica, una instrucción del lenguaje 
BASIC de este ordenador. 
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Por ejemplo, PRINT transfiere datos desde la memoria 
central hacia un periférico, mientras que GOTO no efectúa 
ninguna operación con los datos, sino que cambia el orden 
de ejecución de las instrucciones. 

Prosiguiendo con este examen, se observa cómo es po- 
sible reconocer cuatro familias, o categorías principales, de 
instrucciones diferentes, dentro de las cuales se pueden in- 
cluir con facilidad todas las demás instrucciones no funda- 
mentales. Cuanto estamos diciendo para el BASIC tiene va- 
lidez para todos los lenguajes de programación (FORTRAN, 
COBOL, PASCAL)... porque son aspectos intrínsecos del fun- 
cionamiento de los ordenadores ES modernos. 

Las cuatro familias de instrucciones son las siguientes: 


O declarativas 

O de a y de salida 
O de cálculo y de as signación | (aritméticas) 
O de dal 


En la figura 2 puede ver una representación de estas fa- 
milias y algunas de las instrucciones de BASIC asociadas a 
cada una. 


Fig. 2.—Familias de instrucciones del BASIC y algunos de sus “miem- 
bros”. 


39 


Instrucciones de entrada y de salida (E/S) 


Para ser prácticos, comencemos el estudio de las ins- 
trucciones del lenguaje BASIC con las que permiten escri- 
bir inmediatamente programas pequeños y sencillos: son las 
instrucciones de E/S (1/0, si se quiere utilizar la abreviatura 
de la denominación inglesa "Input/Output”). 

Las instrucciones declarativas que veremos inmediata- 
mente después son muy importantes desde el punto de vis- 
ta conceptual, pero son menos significativas para desarro- 
llar los primeros ejemplos de programas. 

Las instrucciones de entrada y de salida son las que per- 
miten al ordenador recibir datos (entrada) y proporcionar 
resultados (salida). Si alguien piensa que son menos impor- 
tantes que las de cálculo, es decir, las instrucciones que rea- 
lizan los procesos propiamente dichos, se equivoca. Las ins- 


trucciones de entrada y de salida son, pi motivos, 


las mas C 
Por su empleo más 
un buen programador 

En BASIC, las instrucciones más importantes de este 
grupo son INPUT y PRINT, Ya vimos su utilización en algu- 
nos programas anteriores. Entre las instrucciones de entra- 
da y de salida, si queremos ser más precisos, hay también 
las que ponen en comunicación el ordenador con las me- 
morias exteriores, las grabadoras de cinta de casete o las 
unidades de disco flexible y también las que programan el 
empleo de las impresoras, de los joysticks y de los paddles 
(ver volumen número 1 de la B.B..). Todo aquello que va ha- 
cia el ordenador o que gira a su alrededor, se denomina en 
la jerga Entrada/Salida. 


Input 


La instrucción INPUT debe ir acompañada por una lista 
de variables, Cuando durante la ejecución del programa se 
llega a esta instrucción, a cada una de estas variables se le 
asigna el valor efectivo que introduzcamos por el teclado 
(vea la figura 3). 

Veamos un ejemplo escribiendo un programa que cal- 
cula el producto de dos números dados por el teclado 
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19 INPUT A, B 


c...n..n..no..os 


>] Fig. 3.—Al leer una instrucción INPUT el ordenador espera que in- 
troduzcamos los valores para cada una de las variables de su lista 
(y que cada valor sea del tipo adecuado a su variable). 


10 INPUT A,B 
20C=A*B 
30 PRINT C 


En la línea 10 encontramos indicadas dos variables (A 
y B) que, según las reglas del BASIC son variables numéri- 
cas (repetimos que si fueran seguidas por el signo $ serían 
alfanuméricas o de cadena). INPUT A, B, significa: dar un va- 
lor para A y otro para B, tecleándolos durante la ejecución 
del programa. 

La línea 20 contiene el cálculo, propiamente dicho, del 
producto (en los ordenadores, la multiplicación se indica 
casi siempre por el asterisco *). El resultado es “asignado” 
a la variable C, es decir, se introduce en ella. 

En la línea 30, el programa hace que el valor del pro- 
ducto (C) se visualice en la pantalla (PRINT C). 

Probemos a ejecutarlo (una vez escrito, claro). 


RUN 
226,12 
312 


El signo de interrogación es un signo de aviso (en in- 
galés, “prompt”) que el ordenador envía a la pantalla para re- 
cordarnos que debemos responder a una instrucción de en- 
trada, Es interesante observar que la coma que escribimos 
después del primer número indica simplemente una sepa- 
ración entre el primer dato y el segundo. Si hubiésemos que- 
rido multiplicar números fraccionarios o reales, para los que 
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normalmente usamos una coma (3,1416) habríamos tenido 
que emplear el punto en lugar de la coma como es habitual 
en los países anglosajones. Veamos un ejemplo en el que 
se quiere multiplicar 3,14 por 0,005: 


RUN 
23,14, 0.005 
0.0157 


A este respecto debemos indicar que, excepto si se ex- 
plicita lo contrario, el BASIC suele tomar toda variable nu- 
mérica como de simple precisión. En caso de que no la que- 
ramos de ese tipo deberemos usar los sufijos % o tt ya vistos. 

La instrucción INPUT permite enviar a la pantalla un 
mensaje de aviso más detallado. Veamos un ejemplo: 


10 INPUT “DAME DOS NUMEROS ”“,A,B 
29 C=AXB 
30 PRINT C 


Es decir, el mensaje se “encierra” entre comillas. 
Su ejecución es: 


RUN 
DAME DOS NUMEROS 29,3 
6r 


Ok 


De este modo, sobre todo cuando en un programa hay 
muchas instrucciones INPUT, podemos asociar a cada una 
de ellas un mensaje para indicar qué es lo que nos pide y 
cómo deben proporcionarse los datos a la entrada. 

Hemos dicho que en BASIC hay también variables que 
permiten procesar cadenas de caracteres. A continuación 
damos un ejemplo de cómo introducirlas: 


10 INPUT "COMO TE LLAMAS? ”,NOMBRES 

20 PRINT "BUENOS DIAS” 

30 PRINT NOMBRES 

49 PRINT “HAS APRENDIDO EL USO DE LAS 
CADENAS” 
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RUN 


COMO TE LLAMAS? IGNACIO 
BUENOS DIAS 

IGNACIO | 

HAS APRENDIDO El USO DE LAS CADENAS 
Ok 


Print 


Pasamos ahora a la instrucción de salida más importan- 
te: PRINT. Vimos ya en muchos ejemplos anteriores cómo 
se emplea. Después de la palabra PRINT se indican las va- 
riables objeto de visualización. Es posible visualizar tam- 
bién, de forma directa cálculos numéricos, o con cadenas, 
como resulta fácil comprender a partir del ejemplo siguiente: 


10 PRINT 3%X6+10 
29 PRINT "HAS *+"VISTO?” 
Ok 


HAS VISTO? 
Ok 


Cuando se visualizan variables, o datos, con la instruc- 
ción PRINT es posible “controlar” la posición en la que apa- 
recerán en la pantalla, mediante el empleo de dos separa- 
dores: "coma” o “punto y coma”, tal como indicamos con an- 
terioridad. Veamos mejor su utilización con algunos ejem- 
plos: 


10 A = 234 

20 B = 345 

30 C = 456 

40 PRINT A, B, C 

RUN 

234 245 456 


En la línea 40, las variables A, B y C están separadas 
por comas. Por este motivo aparecen a partir de algunas po- 
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sicic”es fijas de la pantalla (aunque diferentes para cada or- 
denador). 

Si cambiamos las comas por puntos y comas en la línea 
40, obtendremos unos números prácticamente "pegados", 
salvo que dejemos espacio para un eventual signo menos 
de los números negativos. 


10 A = 234 

20 B =345 

30: =:456 

40 PRINT A; B;C 
RUN 

234 235 456 


Si ponemos una coma o un punto y coma después de 
la última variable de una instrucción PRINT, haremos que la 
instrucción PRINT sucesiva no se inicie en una nueva línea, 
sino que continúe en la misma. Veamos un ejemplo: 


10 Af="PACO” 

20 E$="PEREZ” 

30 PRINT 48; 

40 PRINT B2£, 

30 PRINT A%,B€ 

RUN 

PACOPEREZ PACO PEREZ 
Dk 


Si no hubiésemos puesto el punto y coma en la línea 30 
ni la coma en la 40, hubiéramos tenido como resultado: 


30 PRINT 4% 

40 PRINT 6% 

30 PRINT 4%,B$ 

RUN 

PACO 

PEREZ 

PACO PEREZ 
Ok 


El programa de la Figura 4 es muy sencillo, pero sirve 
para ilustrar cómo es posible iniciarse en la realización de 
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VE REMO OOOO OOROJOIOIGOROoOR 


22 REM * 


190 
119 
120 


130 


ISE 
(EA 


CREACION DE UN DAMERO 
MO REM OOOO OOOOOIOIOOIOOOOIGIOGIOROR 


L1F="XXk 


L2$=" 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
PRINT 
END 


FX AR 
AX XxX 


Ex 
Xx 


FX EX 
Ek XX 


** 
AX 


AX AX 
AX K* 


RR RX 
EX XX 


xx 
Ak 


xR 
L1$ 
L1$ 
L2$ 


k 
* 
xk 
4x 
* 
* 
xx 
*x 


xx 


xk 
*x 


cias al empleo de cadenas. 


RR AX 
4 


k EX 
k  *X 
Ek  * 
KK XK 
k  Xx* 
Xk xk 


EX 


XK XX 
ES 


xk 


” 


Fig. 4—Ejemplo de programa en BASIC con la instrucción PRINT y 
Y de su ejecución, que proporciona un damero esquematizado gra- 
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gráficos con la sola instrucción PRINT. En las líneas 100 y 
110 de dicho programa se preparan dos cadenas de aste- 
riscos. Al visualizarlas luego de forma alternada, por pare- 
Jas, se obtiene en la pantalla un damero. 

Las comillas que hay al comienzo y al final de los valo- 
res de variables alflanuméricas (en nuestro ejemplo antes y 
después de los asteriscos de L1$ y L2$) no forman parte de 
las > S 


cadenas proplamente dichas: son usada: 


> POr e 


1isamente para delimitar los caracter 


realmente la cadena 

La elección de los asteriscos se hizo exclusivamente 
para hacer más uniforme el damero, pero podría haberse 
elegido cualquier otro carácter. 


Instrucciones declarativas y los arrays 


Las instrucciones declarativas son de las más importan- 
tes en los lenguajes de programación modernos. Sirven para 
“declarar”, como su propio nombre indica por anticipado, de 
qué tipo o características son determinadas variables y, por 
consiguiente, cómo podrán y deberán ser utilizadas. Gracias 
a estas declaraciones, todo el programa se ejecutará más co- 
rrectamente y también resultará más fácil de comprender a 
quienes lean su listado. 

En el lenguaje BASIC ordinario existe una sola instruc- 
ción de declaración: DIM, que es la abreviatura de “dimen- 
sión”. Tratemos de comprender lo que significa y su forma 
de empleo. Para introducir la instrucción DIM debemos ha- 
blar primero de un nuevo tipo de variable que los ingleses 
llaman “array” (literalmente “hilera”) y que podemos deno- 
minar "variable con índices” aunque se suele emplear tam- 
bién el término inglés, o a veces “vector”, o "matriz". Como 
siempre, vamos a introducir el nuevo concepto a través de 
un ejemplo. 

Supongamos que estamos en un laboratorio en donde 
es preciso realizar una serie de medidas experimentales. So- 
bre los datos de estas medidas deberemos efectuar des- 
pués diversos análisis estadísticos: cálculo de los valores 
medio, mínimo, máximo, etc. Es, pues, necesario poder re- 
coger los datos en una serie de variables, con las cuales 
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efectuar luego los cálculos. Si los datos son pocos, por ejem- 
plo 5, podríamos escribir: 


100 INPUT Dl 
110 INPUT D2 
120 INPUT D3 
130 INPUT D4 
140 INPUT DS 


y luego emplear las cinco variables Dl, D2, D3, D4 y D5 para 
los cálculos. En nuestro caso, el valor medio sería: 


200 VM = (D1 + D2 + D3 + D4 + D5) / 5 


Los otros cálculos serían más complejos largos y tedio- 
sos, aunque factibles. Pero, ¿qué ocurriría si tuviéramos 100 
ó más datos? Sería impensable utilizar otras tantas variables 
para contenerlos, puesto que la escritura de las operacio- 
nes se haría simplemente imposible. Para nuestra comodi- 
dad, no obstante, el BASIC nos proporciona un instrumento 
para resolver el problema: el array O variable con índices. 

Un array no es otra cosa que un co munto oraenaao ce 
variables simples reunic ajo un mismo nombre. En el 
caso más elemental, el del array con un solo índice (o vec- 
tor), podemos pensar en una fila de casillas numeradas, cada 
una de las cuales (elemento del array) es una variable sim- 
ple (Figura 5a). En nuestro ejemplo (Figura 5b), las cinco va- 
riables diferentes D1, D2, D3, D4 y D5, se convierten en los 
cinco elementos D(1), D(2), D(3), D(4) Y D(5) del array D. 
¿Dónde está la diferencia? Lo veremos inmediatamente con 
el ejemplo siguiente: 


E a 


100 FOR 1=1 TO 5 
110 PRINT D (D) 
120 NEXT 1 


Este pequeño programa imprime los valores de las cin- 
co variables. La línea 100, en la que usamos el conjunto FOR. 
NEXT todavía no explicado, indica que ha de repetirse todo 
cuanto sigue hasta la línea 120 (NEXT) hasta que el valor de 
I que parte inicialmente de 1 y aumenta 1 en cada paso, val- 
ga 5. La línea 100 imprime el valor del elemento número 1 
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a) 
Vector D 


Cada elemento es 
una variable simple 


DATO 3 


Av Fig. 5.—(a) Ejemplo de arra y de un solo índice (vector). (b ) Corres- 
Y pondencia con los datos del laboratorio. 


del array D; es decir, el valor de la L-ésima casilla del array. 
En la primera “vuelta”, I vale 1 y por ello la línea 100 equi- 
vale a PRINT D(1), que imprime el valor elemento de D. En 
la segunda vuelta, l vale 2 y se imprime el valor contenido 
en el segundo elemento y así sucesivamente. Así, si hubié- 
ramos medido en el laboratorio los valores 125, 259, 386, 42] 
y 536 la ejecución del programa será: 


RUN 
125 
259 
386 
421 
536 


El mismo programa de tres instrucciones podría impri- 
mir 2000 valores, con la simple sustitución de la línea 100 
por FOR I= 1 TO 2000. Las instrucciones FOR y NEXT cons- 
tituyen un “bucle” pero de ellas hablaremos más extensa- 
mente en este mismo capítulo al tratar de las instrucciones 
de control. 
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Los arrays no están limitados a un índice (o dimensión); 
$e pueden 1 tener arrays con dos Índices (matrices), que po- 
demos considerar como “tableros” u hojas cuadriculadas (di- 
vididas en líneas y columnas), en las que cada ca con- 
tiene el valor de una variable simple (figura 6) e incluso con 
tres o más indices. De hecho el BASIC no suele imponer lf- 
mites al número de dimensiones, 

De cualquier modo, los arrays más utilizados son los de 
una y dos dimensiones (í ínc 8), que suelen amas vec- 
tores y matrices, respectivamente. 


Al igual que las variables, los arrays tienen también su 
tipo, que debe ci dir con el de los 


mentos que con- 
tienen y que se indica con los habituales sufijos. 


Matriz D 
(array) 


Fila (línea) 


Cada elemento es 
una variable simple 


e Fig. 6.—Ejemplo de array con dos índices (matriz) 
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Por ejemplo: 


A(5)JEs el quinto elemento del array numérico 
real A 

XY(40) Es el elemento cuadragésimo del array 
numérico XY, 

NOMBRE%(2,3) Es el tercer elemento de la se- 
gunda fila del array alfanumérico NOMBRE$ 


Los dos primeros ejemplos son de una dimensión (vec- 
tores) y el tercero tiene dos dimensiones (matriz). 


Dim 


Las variables con índices son, pues, variables con ma- 
yor capacidad que las normales y pueden contener muchos 
datos. Lo importante es que estos datos sean todos del mis- 
mo tipo: números o Cadenas. 

Así, si tenemos que tratar los códigos de centenares o 
miles de productos de un almacén no precisamos inventar 
centenares o miles de nombres de variables simples, sino 
que nos bastará un solo nombre, por ejemplo CODIGO, y 
avisar al ordenador de que esta variable contendrá miles 
de valores. Esta operación de “aviso” es precisamente una 
declaración de dimensionamiento y se hace en BASIC me- 
diante la instrucción DIM. Veamos algunos ejemplos: 


146 DIM CODIGO (1900) 
10 DIM 4(20,30) 
16 DIM NOMBRES (30), CALLES (30) 


La instruc 1 DIM debe preceder a cualcuier otra en 
la que aparezca la variable 

El lenguaje BASIC acepta que no Smension 1emos ex- 
presamente una variable cuando su dime ups 
rior a 10 Por ejemplo, no es necesario eseribis 


10 DIM A(6) 


Cuando el ordenador encuentra, por primero vez en un 
programa, una nueva variable con un índice inferior o igual 
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a 10, efectúa automáticamente un dimensionamiento de 10 
de esta variable. Si encontrara un índice superior a 10 el BA- 
SIC dará un error por variable no dimensionada. 

Veamos un ejemplo de programa que emplea la ins- 
trucción DIM, (se ilustra en la figura 7). 

Supongamos que en una escuela los alumnos de una 
clase quieren utilizar un ordenador personal para conservar 
las notas obtenidas. El programa debe almacenar los nom- 
bres de los alumnos y junto a cada uno de ellos poner la 
nota obtenidas en la asignatura en cuestión. 

Para resolver este problemas debemos emplear dos 
vectores: uno de cadena y otro numérico. El primero NOM- 
BRE$, para contener los nombres y el segundo NOTAS para 
contener las notas. Puesto que los alumnos serán segura- 
mente más de 10, deberemos dimensionar los dos vectores 
con DIM. Supongamos que los alumnos sean 30; cambiando 
el dimensionamiento (línea 180) se puede emplear el pro- 
grama para cualquier otra clase. ¡Ojo con esto! pues, si cam- 
biamos el número de los alumnos, deberemos hacer lo mis- 
mo en las líneas 230, 320 y 390, con las tres instrucciones de 
bucle FOR NEXT que veremos a continuación. 

Una vez realizado el dimensionamiento de los vectores 
NOMBRE$ y NOTAS, el ordenador puede introducir en el 
primero los nombres de los alumnos (líneas del programa 
desde 200 a 250) y luego, después de haber solicitado la 
asignatura objeto de la calificación (línea 270 y 280), se car- 
gará el vector de las notas (líneas desde 300 a 350), Final- 
mente, el programa imprime el “archivo” y con ello se vi- 
sualizarán en la pantalla las notas. 

Evidentemente un programa de esta naturaleza es algo 
"ingenuo”, pero resulta fácil pensar que, si añadimos las ins- 
trucciones del BASIC necesarias para almacenar en disco 
las calificaciones y para imprimirlas luego en papel, se ob- 
tendrá un verdadero programa profesional. Estas instruccio- 
nes las veremos más adelante. 

El lector imaginativo ya habrá pensado sin duda que no 
hay razón para limitar las calificaciones a una sola asignatu- 
ra cada vez. En efecto, podríamos hacer el array NOTAS de 
dos dimensiones, de forma que cada línea representara un 
alumno y cada columna una asignatura (cuyo nombre esta- 
ría en el ahora vector ASIGNATURAS). Tendremos entonces 
(para, p. e, 7 asignaturas): 
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1 REM OOOO OOOO OR 

119 REM Kk k 

120 REM * ARCHIVO DE LA CLASE  % 

1232 REM k X 

140 REMO OOOO IO OOOIOROIOOOOIOIOROOIOIOK 

150 REM 

168 REM DIMENSIONAMIENTO DE LOS 
VECTORES 

170 REM ALUMNOS Y CALIFICACIONES 

189 DIM NOMBRES (30) NOTAS (30) 

190 REM 

200 REM BUCLE PARA CARGAR 

219 REM LOS NOMBRES DE LOS ALUMNOS 

22 PRINT "DAR NOMBRE A LOS ALUMNOS” 

'PRINT 

220 FOR K=1 TO 30 | 

240 INPUT NOMBRES (K):REM INTRODUCCION 
DEL NOMBRE 

258 NEXT K 

262 REM 

279 REM SOLICITUD DE LA ASIGNATURA 

289 INPUT “QUE ASIGNATURA”; ASIGNATURAS 

292 REM 

300 REM BUCLE DE CARGA DE NOTAS 

310 PRINT "DAR LAS NOTAS DE ”; 
ASIGNATURAS: PRINT 

328 FOR K=1 TO 30 

339 PRINT “NOTA DE ”;NOMBRE$(K) ; 

340 INPUT NOTAS (K) 

350 NEXT K 
REM 

370 REM IMPRESION DEL REGISTRO 

380 PRINT "CALIFICACIONES DE ”; 

- ASIGNATURAS 

39% FOR K=1 TO 30 

409 PRINT NOMBRES (K),NOTAS(K) 

412 NEXT Kk 

420 REM 

438 END 


caca! 
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DIM NOMBRE%X(30), NOTAS (30,7) 
DIM ASIGNATURAXK7) [esta no sería imprescidible] 


Por supuesto, los bucles que harían falta en esta nueva 
estructura (ver figura 8) no serían los mismos que, antes aun- 
que sí parecidos. ¿Se atreve a hacer el nuevo programa? En 
la Figura 9 les ofrecemos una de las mucha soluciones vá- 
lidas que resuelven el problema, y una ejecución. Si se fija 
verá como el array NOTAS se encuentra siempre “encerra- 
do" entre dos bucles FOR... NEXT. ¿Por qué? Lo que hace- 
mos es que el primer bucle (p.e. el que comienza en la lí- 
nea 280) controla la variación del alumno (primer índice de 
NOTAS, como se ve en la Figura 8) y el segundo bucle (p.e. 
en la línea 300) hace lo propio con las asignaturas. De esta 
forma, para cada uno de los alumnos (FOR K = 1 to NAL) to- 
mamos todas sus notas [FORL=1 TO NAS] antes de pasar al 
siguiente. Esta estructura, denominada de "bucles anidados”, 
la veremos más en detalle al tratar de la instrucción FOR.. 
NEXT; será sin duda un buen momento para repasar de nue- 
vo este programa 


ASIGNATURAS 


ASIGNATURAS (7) 


MATEMATICAS 


NOMBRES (1) 
Nieto en Lengua) 


NOTAS (1, 7) 
(nota de Francisco 


NOMBRES (30) 
NOTAS (30, 7) 


NOMRR.ES NOTAS 


y Fig. 8.—Nueva estructura de los arrays usados al “ampliar” el pro- 
grama de la Figura 7. 


REM IOAOOOGOIOIOOOIOIOIOGIOOIOOIOOICIOO(O 
REM X ALUMNOS Y ASIGNATURAS X 
REM OGIORIOOOOOOOIOOIOIOIOOIOOIOIOOIOR OJO 
INPUT “NUMERO DE ALUMNOS”; NAL 
INPUT "NUMERO DE ASIGNATURAS” ¡NAS 
PRINT 

REM OGIOOIOOOOOOIOOIOIOOIOOOIODO RA 
REM *X DIMENSIONO LOS ARRAYS * 
REM OROOOIOOIOIOOIOIOOOIOIOIIOROIOIOOIOIIOK 


9 DIM NOMBRES (NAL), NOTAS (NAL,NAS), ASIGNATURAS (NAS) 


REM IOOOIOOGOIOIOIOIOIOIOIOROIOIOIOROJOIOIOo(OK 

REM X NOMBRE DE LOS ALUMNOS XK 

REM IOCIOROOOROIODIOOOIOIOIOODOOONK 

FOR I=i TO NAL 

PRINT "NOMBRE DEL ALUMNO NUMERO”; 1; 

INPUT NOMBRES (1) 

NEXT 1 ' 

REM ROIOIO OOOO OOOO IOIOIOROIOJOK 

REM * NOMBRES DE LAS ASIGNATURAS *X 

REM IOGORIOOOOOOIORIOIOIOIOOIOROIOIOIGIOROIOOOONR 

FOR J=i TO NAS 

PRINT “NOMBRE DE LA ASIGNATURA ";J; 

INPUT ASIGNATURAS (J) 

NEXT Y 

REM IGIOOIOIOIOGOOIOROIOIOIO DIOS ISI lOPIOIO OOO JOOR 
REM X NOTAS PARA CADA ALUMNO Y ASIGNATURA XK 
REM OOOO OOOO OOO OOOO OOOO OIOIOROIGROIOIOIOOJON 
FOR K=1 TO NAL 


| PRINT "ALUMNO D, ” ¡NOMBRES (K) 


FOR L=1 TO NAS 

PRINT "NOTA EN "¡ASIGNATURAS (L); 
INPUT NOTAS (K,L) 

NEXT L 

NEXT K 

REM GOOIOOOOIOIOIOOIOOIOOROIOJPOJOjOK 
REM k SALIDA DEL ARCHIVO *X 
REM OOOO RGIOIOIOOOIOIOIOIBIOROOIOIOIOION 
PRINT "NOTAS OBTENIDAS EN:” 
PRINT, 

FOR I=1 TO NAS 

PRINT ASIGNATURAS (1), 

NEXT 1 

PRINT 

PRINT “POR LOS ALUMNOS SIGUIENTES: ” 
FOR J=1 TO NAL 

PRINT ”D, "¿NOMBRES (J), 

FOR K=1 TO NAS 

PRINT NOTAS (J,K), 

NEXT K 


509 PRINT 
310 NEXT Y 
3520 END 


NUMERO DE ALUMNOS? 3 


NUMERO DE ASIGNATURAS? 4 


NOMBRE DEL ALUMNO NUMERO 
NOMBRE DEL ALUMNO NUMERO 
NOMBRE DEL ALUMNO NUMERO 
NOMBRE DEL ALUMNO NUMERO 
NOMBRE DEL ALUMNO NUMERO 
NOMBRE DE LA ASIGNATURA 
NOMBRE DE LA ASIGNATURA 
NOMBRE DE LA ASIGNATURA 
NOMBRE DE LA ASIGNATURA 


ALUMNO D,F.RUIZ 
NOTA EN FISICA? 5 
NOTA EN QUIMICA? 3 
NOTA EN ALGEBRA”? 6 
NOTA EN GEOLOGIA? 3 
ALUMNO D.E, ZAMORA 
NOTA EN FISICA? 4 
.NOTA EN QUIMICA? 5 
NOTA EN ALGEBRA? 3 
NOTA EN GEOLOGIA? 4 


ALUMNO D.A,BAUTISTA 
NOTA EN FISICA? 8 
NOTA EN QUIMICA? 7 
NOTA EN ALGEBRA? 9 
NOTA EN GEODLOGIA? 5 
ALUMNO D.F, NIETO 
NOTA EN FISICA? 5 
NOTA EN QUIMICA”? 6 
NOTA EN ALGEBRA? 8 
NOTA EN GEDLOGIA? 3 
ALUMNO D.C. GONZALEZ 
NOTA EN FISICA? 3 
NOTA EN QUIMICA? 5 
NOTA EN ALGEBRA? 4 
NOTA EN GEOLOGIA? 19 


PU mu” a mou 


A 


F.RUTZ 

E, ZAMORA 
A, BAUTISTA 
F.NIETO 

C. GONZALEZ 
FISICA 
QUIMICA 
ALGEBRA 
GEOLOGIA 


55 


NOTAS OBTENIDAS EN: 
FISICA QUIMICA ALGEBRA GEOLOGIA 


POR LOS ALUMNOS SIGUIENTES: 
D. F.RUIZ 


5 
D, E, ZAMORA 4 
D, A,BAUTISTA 8 
5 
3 


A O A E] 


D. F.NIETO 
D, C,GONZALEZ 
Ok 


0 JJ ín a 


6 
5 
9 
2 
4 


EN Fig. 9.—Una de las posibles soluciones, y su ejecución, para ampliar 
el programa de la Figura 7 a 7 asignaturas. 
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INSTRUCCIONES ARITMETICAS Y MANEJO DE 
CARACTERES 


Instrucciones de asignación 


as instrucciones de asignación son las más 

sencillas, pero permiten desarrollar el tra- 

bajo efectivo que pedimos a un ordenador. 

Con estas instrucciones se pueden realizar 

cálculos matemáticos con datos numéricos 
y manejar las cadenas de caracteres. 

La instrucción más típica de este grupo 

; es la instrucción LET; que permite atribuir 

un oler a una variable. Vimos ya algunos ejemplos de asig- 

nación, pero consideramos de utilidad ver algunos otros: 


10 LET A=35 

20 LET B=12 

30 LET F$="JOSE” 

40 PRINT A,B,FS 

Ok 

RUN 

33 12 JOSE 
Ok. 


La palabra LET (que significa “poner” o "hacer”) fue uti-.. 
lizada en las primeras versiones del BASIC, pero actualmen- 
te en la mayor parte de los ordenadores no es necesario uti- 
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lizarla, Basta escribir directamente el nombre de una varia- 
ble a la izquierda del signo igual. 


10 A=(10+25)43 

20 B=38-3 

30 C=A-B 

40 R$="RESULTADO=" 
30 PRINT R$;C 

Ok 


RUN 
RESULTADO= 70 
Ok 


El ZX Spectrum es uno de los pocos ordenadores don- 
de esto no cabe. Al tener un teclado especial, cuyas teclas 
llevan grabadas las palabras reservadas de su dialecto BA- 
SIC, requiere el empleo obligatorio de la instrucción LET. 

La existencia del signo igual (=) en las instrucciones LET 
nos op a ! hacer ipeciatamento una A purmalacón im- 
portante, El sic gno lg = z ) una 
dad matemáti ; 1 ¿ en la es: 

El significado Aja 7 signo en los me rs seat se ex- 
plica como sigue: calcular primero el valor de todo lo que 
está a la derecha del signo igual según la expresión corres- 
pondiente y luego asignar el resultado a la variable que está 
a la izquierda. En el primer miembro deberá estar siempre 
una sola variable y por ello, escribir en BASIC: 


1056* 3=B 
10. A =10=R 


es absolutamente erróneo. Sin embargo podemos hacer una 
cosa en principio tan "rara” como: 


10A=A+10 


¿Cómo interpreta esto el ordenador? Primero calcula lo que 
hay a la derecha del igual, es decir, suma al valor de A,10, 
Luego ese resultado es asignado a la variable A borrando 
su anterior valor. En este caso, por ejemplo, habremos in- 
crementado en 10 unidades el valor de A. 
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Otras instrucciones de asignación del BASIC (DATA, 
READ y RESTORE) las dejaremos para el capítulo siguiente. 


Instrucciones de cálculo 


Hemos dicho que a la derecha del signo igual pueden 
escribirse expresiones numéricas o alfanuméricas. Vamos a 
ver cuáles son las reglas para escribirlas en BASIC. 

Las expresiones matemáticas, en BASIC, son práctica- 
mente idénticas a las que se estudian en la escuela, con al- 
gunas pequeñas diferencias en la escritura de los operado- 
res (los símbolos de las operaciones). 

Tomemos el ejemplo de una expresión algebraica, es- 
crita como hacemos normalmente y probemos a volverla a 
escribir el el lenguaje BASIC. Para ello, tenemos que em- 
plear los símbolos de las operaciones algebraicas (opera- 
dores algebráicos) admitidos por el BASIC (Figura 1). 


A+B A+B 
A-B A-B 
AXB 
A-:B A*B 
AB 
A 
B A/B 
AB 
A**B 
AB ATB 
AB 


Como se puede constatar, las operaciones de suma y 
resta se indican como es habitual con "+" y "-”. 

El producto se indica, en cambio, por el asterisco “*” y 
no por “x” o el punto como se emplea en matemáticas. A me- 
nudo también indicamos el producto de dos valores simple- 
mente escribiéndolos uno después de otro. Así, con “a b”. 
queremos decir “a por b”. Esto no vale en BASIC. Nunca po- 


demos dejar algo sobreentendido en informática, por lo que 
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“Algebra: CAN 


Potencia] 


ra | 


Fig. 1.—Operadores algebráicos 


el producto debe indicarse de forma expresa mediante el 
asterisco: A * B (obsérvese que en BASIC se utilizan las le- 
tras mayúsculas). 

La división viene indicada por el carácter “/" (en inglés, 
slash). Los dos puntos "” tienen en BASIC un significado 
completamente distinto que no coincide en todas las versio- 
nes. 

La elevación potencia es otra operación con un 
símbolo particular. Nós se escribe el exponente como un nú- 
mero más pequeño colocado arriba a la derecha de la base 
como “4?” Se sitúan la base y el exponente en la misma lí- 
nea, separados por uno de los símbolos "**”, "?" y "", es de- 
cir, Ea AUEAgO ejemplo, 4 eS, 473 ba también 4 a 

) Ol especti parénte Os únicos que s 
utuzan en las expresiones son 1os redondos, que desemripe 
misma lunción ] en mate lráticas 

En la obra 2 hemos indicado las funciones matemátl 

; más comunes. Observe que la raíz cuadrada de un mú- 
mero X en BASIC se indica por SQR(X). “SQR” es la abrevia- 
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cosoo 


TANO) 


Fig. 2 —Funciones matemáticas 


tura de las palabras inglesas "square root”, que quiere decir 
"Taíz cuadrada”. 

Otras funciones matemáticas que suelen encontrarse in- 
mediatamente en BASIC son la cs EXP(X) y su in- 
versa LOG(X) que e (cuidado con 
esto, pues en la notación de: Ender por casa” usábamos LOG 
como logaritmo en base 10 y LN como el de base “e”), junto 
a las funci létricas seno, conseno y tangente, 
SINGO, COS(X) y TANGO) respectivamente. De estas e al 
funciones es prosa reparar que normalmente efiere 
a ángu : (2 7r radianes = 360 9). Si 
tenemos un , ángulo ido en grados, para calcular su 
valor en radianes basta multiplicarlo por: 


Xrad = Xgrad* (3,1416/180). 


En la figura 3 damos algunos ejemplos de expresiones 
matemáticas escritas en BASIC. 


61 


x+ y 
x+z 


(4 Y) / (Y + Z) 


3 + [(5 + A) (B + C)] 


3 + ((5 + A) - (B + C)) 


LOG (528) 


SOR((1 +X) / (1 + Y))* (TAN (Y) + 
+ EXP (X— 2)) 


px 


v14+y 


(tg (y) + e*”2) 


Fig. 3.—Algunas expresiones matemáticas y sus equivalencias co- 
rrespondientes en BASIC 


Ejemplos de programas matemáticos 


Veamos ahora un programa en el que se calculan algu- 
nas expresiones algebraicas. La primera sirve para obtener 
el volumen de un paralelepípedo y la segunda para el de 
una esfera. El listado correspondiente es como sigue: 


19 PRINT "PROGRAMA PARA EL CALCULO DE VOLUMENES” 
BO PRINT Pe 
390 PRINT 

49 PRINT "CALCULO DEL VOLUMEN DE UN PARALELEPIPEDO” 
30 INPUT "ALTURA”;H 

60 INPUT "LONGITUD”;LG 

70 INPUT "ANCHURA”;LA 

80 V=LAXLGXH 

99 PRINT "EL VOLUMEN ES ”; 

100 PRINT Y 

110 PRINT 

129 PRINT “CALCULO DEL VOLUMEN DE UNA ESFERA” 
139 INPUT “RADIO DE LA ESFERA”";R 
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140 Y=3,1416%(4/3)*R"3 

150 PRINT "EL VOLUMEN DE LA ESFERA ES ”; 
160 PRINT Y 

170 END 


El programa pide las dimensiones del paralelepípedo 
(altura, longitud y anchura) y luego, en la línea 80 las mul- 
tiplica entre sí para calcular el volumen y asigna el resulta- 
do a la variable V, sacando a pantalla el resultado. A conti- 
nuación, pide el radio de una esfera y calcula su volumen 
en la línea 140. 

Observe que se emplea el mismo nombre de variable 
(V) tanto para el volumen del paralelepípedo como para el 
de la esfera. Esto es posible con tal de que se utilice de for- 
ma correcta, es decir, que sepamos que no interfieren am- 
bos usos. 

Tratemos de aclarar este punto. Inicialmente, V no con- 
tiene nada. En la línea 80 se le asigna el valor del volumen 
del paralelepípedo. Inmediatamente después, en la línea 
100, se visualiza con PRINT V su contenido. Posteriormente 
(línea 140) se calcula el volumen de la esfera que se asigna 
a la misma variable V; desde este preciso momento, V con- 
tiene solamente el volumen de la esfera y el del paralele- 
pípedo ha sido borrado. En efecto, ahora solo nos interesa 
el volumen de la esfera que se visualizará con PRINT V (lí- 
nea 160). Si, por ejemplo, hubiéramos deseado visualizar los 
valores de los dos volúmenes al tiempo hubiera sido nece- 
sario asignar el valor del de la esfera a otra variable que no 
fuera V (p.e. VE) para poder conservar el valor del volu- 
men del paralelepípedo y poder hacer un PRINT V, Ve. 

Veamos un ejemplo de ejecución del programa: 


RUN 
PROGRAMA PARA EL CALCULO DE VOLUMENES 


CALCULO DEL VOLUMEN DE UN PARALELEPIPEDO 
ALTURA? 5 

LONGITUD? 6 

ANCHURA? 8 

EL VOLUMEN ES 240 


CALCULO DEL VOLUMEN DE UNA ESFERA 
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RADIO DE LA ESFERA? 5 


EL VOLUMEN DE LA ESFERA ES 523,6 

Ok 

Este ejemplo confirma que las variables en Informática 
e comportan como cajas en las que se pueden meter co 
sas “adecuadas” cuando queramos, pero teniendo en cuen 


e el último objeto introducido "echa a la calle" al que 


estaba anles, 


Veamos un segundo programa, ejemplo de cómo se 
puede llevar una pequeña contabilidad y calcular valores 


porcentuales. 


Supongamos que hemos hecho un viaje y queremos sa- 
ber cómo se han repartido los gastos, en porcentajes, entre 
el automóvil, el hotel y los restaurantes. Después de haber 
recibido los datos por el teclado, en la línea 90 se calcula 
el total de los gastos, que se conserva en la variable T. En 
las líneas 100, 110 y 120 se calculan los tres porcentajes y 
se asignan, respectivamente a las variables APERC, HPERC 


y RPERC. 
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REM PROGRAMA PARA EL CALCULO 

REM DE LA DISTRIBUCION PORCENTUAL 
REM DE GASTOS 

REM CON OCASION DE UN VIAJE 

REM 

INPUT "GASTOS AUTOMOVIL ”:A 

INPUT "GASTOS HOTEL “;H 

INPUT “GASTOS RESTAURANTE ”¿R 
TSA+H+R 


0 APORC=A*(100/T) 


HPORC=HX (100/T) 
RPORC=RX (100/T) 


PRINT "GASTOS AUTOMOVIL EN %="; 
APORC . 
PRINT "GASTOS HOTEL EN %="”;HPORC 
PRINT "GASTOS RESTAURANTE EN %="; 
RPORC 

END 


prueba de ejecución: 


GASTOS AUTOMOVIL ? 200909 

GASTOS HOTEL ? 120000 

GASTOS RESTAURANTE ? 33990 
GASTOS AUTOMOVIL EN %= 11,42857 
GASTOS HOTEL EN %= 68,57143 
GASTOS RESTAURANTE EN %= 20 

Ok 


Este último ejemplo quizá les pareciera banal y tengan 
ganas de preguntarnos por qué utilizar un ordenador, o es- 
cribir un programa, para cálculos que se realizan con ma- 
yor facilitad mediante una calculadora de bolsillo. La res- 
puesta es que se trata solamente de unos ejemplos, que te- 
nían que ser lo más sencillos posible. Lo que cuenta, por aho- 
ra, es el principio. Un programa efectivo podría realizarse, 
más o menos, del mismo modo; trabajar no con tres elemen- 
tos, sino con un centenar, recibir los datos no a través del 
teclado, sino a partir de un fichero de disco, e incluso po- 
dría trazar también un “gráfico” de la distribución de los gas- 
tos o extrapolar (predecir sobre la base de los datos ante- 
riores) previsiones para los años sucesivos, pero el sistema 
de programación aplicado sería el mismo. 


Variables alfanuméricas. Funciones ASC y CHR$ 


Una variable numérica contiene números y una varia- 
ble alfanumérica o de cadena, contiene caracteres. Estos ca- 
racteres, para ser almacenados en el ordenador (que, recor- 
demos, es una máquina que sólo maneja información en for- 
ma digital) deben estar codificados en una forma numérica 
apropiada. A cada carácter se le asocia un número según el 
código particular elegido. 

Entre los numerosos códigos posibles, los ordenadores 
personales han adoptado el código ASCII (ver el Apéndice 
A y repasar cuanto se dijo en el primer volumen de nuestra 
colección), código que hace corresponder a las letras, ci- 
fras, signos de puntuación y demás caracteres números que 
van desde el O al 255.Por ejemplo, las 26 letras del alfabeto 
inglés están codificadas con los números 65 a 91, mientras 
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que las diez cifras decimales están codificadas desde el 48 
al 57 y la coma con el valor 44, Gracias a este código los 
ordenadores pueden contener y procesar caracteres, pala- 
bras de ilerales enteros. 

N arte, para escriblr programas que traten caí le- a 
aracrteres, no el » 
ar estas en ASC 


jose: torma automátic 


nos 


esaño que nos preccupe 
rque dicha operación se re 

a por el ordenador. Basta pulsar € en 
el fnelade las teclas corsspondientes a los caracteres de- 
seador para que el ordenados los transforme y almacene 
bajo la forma del código ASCII. Lo anterior es válido para 
los caracteres existentes en el teclado. Como se verá, tam- 
bién puede hacerse algo parecido con los demás. 


ASC y CHR$ 


Con este propósito vamos a hablar inmediatamente de 
dos importantes funciones del lenguaje BASIC que transfor- 
man un carácter en su cadigo numérico ASCII y viceversa. 
Dichas funciones son 430 y CHR$. Algunos ordenadores lla- 
man a la primera CODE; en todo caso da res la misma 
función, que es la de proporcionar el código ASCH de un ca- 
rácter. Por ejemplo, si escribimos; 


10 PRINT ASC(A) 


obtendremos: 


RUN 
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que es precisamente el código de la letra A. 
Por el pad la función CHR$ proporciona un carác- 


ter a parti su código ASCII. Probemos con un A Slemplo: 
10 PRINT CHR$(66) 
RUN 
B 
La función $ es de gran importancia en BASIC por- 


'aracteres que no 6 ¡Odemos in- 
u inserción en un programa. 


qué permite * 
troducir por el isclade para s 
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El más importante de todos estos caracteres es el de Re- 
turn, que hace terminar la introducción de una línea o de un 
dato. Si tratamos de utilizarlo como cualquier otro e introdu- 
cirlo entre comillas (como se hace con una cadena normal, 
es decir, poner comillas y pulsar la tecla de RETURN), no lo 
conseguiremos, porque apenas lo hayamos pulsado desem- 
peñará el cometido de introducir un "retorno de carro” en 
el ordenador. Si consultamos la tabla del código ASCII en- 
contramos que el Return tiene el código 13. Así, para intro- 
ducir un Return en cualquier programa basta escribir en BA- 
SIC CHR$(13). 

Para familiarizarnos con las funciones ASC y CHR$ vea- 
mos ahora dos programas: Secretísimo 1 y Secretísimo 2. El 
primero, como los mejores agentes de espionaje, traduce 
una frase a un “código secreto” (con ASC), mientras que el 
segundo la reconvierte a lenguaje normal (con CHR$). 

He aquí el programa Secretísimo 1: 


REM OOOO DIOIOIOIOOOOIONK 

19 REM K SECRETISIMO 1 X 

15 REM OOOO OIOOOIORIGIOGOOON 

20 PRINT "DAME LA CLAVE SECRETA (1-37)"; 

39 INPUT K:IF (K<1) OR (K>37) THEN GOTO 
20:REM CONTROL CLAVE 

40 PRINT "ESCRIBE UNA LETRA A CIFRAR 
(A-Z,R+PARA ACABAR)"; 

5Q INPUT AS: IF(AS<"A”") OR (4$>”2Z") THEN 
GOTO 40:REM CONTROL 

60 IF A$="*" THEN END 

79 B=ASC(A$)+K 

80 PRINT B 

90 GOTO 350 


Comentemos algunas de sus particularidades: 

Las líneas 20-30 piden la “clave secreta”, que se asigna- 
ra a la variable K. 

En la línea 30, en particular, se puede observar cómo se 
construye una entrada controlada, que admite solamente los 
valores que entran en el margen señalado (si la clave no 
está entre 1 y 37, se repite la pregunta de la línea 20). 

Las líneas 40-50, en donde el programa pide una letra a 
cifrar, son otro ejemplo de. entrada controlada. No obstante, 
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el control es diferente al anterior, puesto que compara ca- 
denas en lugar de números. Una expresión lógica del tipo 
IF A$<"A” (IF significa en inglés el si condicional castella- 
no) es verdadera si el primer operando (el contenido de 
A$) precede en orden alfabético (en realidad en el orden 
de los códigos ASCII, pero es lo mismo), al segundo ope- 
rando (“A”). En los ordenadores que no admiten este tipo 
de operación, es preciso comparar los códigos ASCII, en 
este caso, la entrada se escribiría de esta otra forma: 


50 INPUT AS:IF (ASC(A$)XASC("A”)) OR 
(ASC(A$)>A5C("Z”)) THEN GOTO 49 


La línea 60 permite terminar el trabajo de cifrado, pues- 
to que cuando se escribe "*f” se ejecutará la instrucción END 
y terminará el programa. Si el ordenador no admite una ins- 
trucción END en medio del programa, es preciso escribir 


60 IF A$="%$” THEN GOTO 109 
1900 END 


En la línea 70 por último, la letra se cifra sumando K al 
valor de su código ASCII La línea 80 imprime el “cifrado se- 
creto” que ha de transmitirse al “comando operativo”. Por 
ejemplo, si K = 4, se obtendrá una conversión de este tipo: 


A pS R E 0 
69 13 86 13 79 


Se observa que cada valor numérico se obtiene suman- 
do al código ASCII la clave K = 4 (A = 65 + 4 = 69). 

Con el programa Secretísimo 2, el mensaje secreto se 
descifra. Solamente el “comando operativo” que conoce la 
clave, puede efectuar la decodificación. 

Y he aquí el programa Secretísimo 2: 


Y REM IGIORIOOGOIOGOGOIOIOOIOOGIODIGIO.N 

19 REM * SECRETISIMO 2 K 

LS REM GIOOOOIOIOOOOIOOIOROIOIOJDIOIOIOROIOIOJOR 

20 PRINT "DAME LA CLAVE SECRETA (1-37)"; 

30 INPUT K:IF (K<1) OR (K>37) THEN GOTO 
20: REM CONTROL CLAVE 
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40 PRINT "ESCRIBE UN CODIGO A DESCIFRAR 
(0, PARA ACABAR)"; 

50 INPUT C . 

60 IF C=0 THEN END 

79 BF=CHRS (C-K) 

890 PRINT B% 

90 GOTO 50 


En las líneas 20-30 se solicita, como es habitual, la clave 
secreta. 

Las líneas 40-50 piden el código a descifrar. La línea 60 
termina el trabajo si se ha pulsado 0. 

La línea 70 reconstruye el carácter original realizando 
una especie de “decodificación”; primero se resta K (las ope- 
raciones entre paréntesis tienen siempre la prioridad) y lue- 
go, se asigna a B$ el carácter que tiene como código ASCII 
el valor calculado, que no es otro si no el carácter original- 
mente cifrado con el programa Secretísimo 1. Por tanto las 
correspondencias serán, entre otras, para K =4: 


69 73 86 13 719 
A E R E 0 


Operaciones con variables alfanuméricas. Instrucciones +, LEFT$, 
RIGHTS, MIDS y LEN 


Existe un cierto parentesco entre variable alfanumérica 
y array: la primera es una secuencia ordenada de caracte- 
res (figura 4), mientras que la segunda está constituida por 
una serie de elementos numéricos. 

Dos cadenas pueden ser concatenadas, es decir, pue- 
den ser “sumadas” para obtener una cadena resultante cons- 


Fig. 4 —Una cadena, a semejanza de un array, contiene una secuen- 
cia de elementos, cada uno de los cuales es un carácter. 
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“FUERTE” 


“CAJA” 
UN) ...1 UN 


“CAJA FUERTE” 


Fig. 5.—Dos cadenas pueden concatenarse para formar una más lar- 
ga. 


tituída por las dos originales, colocadas una tras otra, tal 
como se ilustra en la Figura 5. 

El operador de concatenación de las cadenas suele ser 
el *+" pero también puede ser otro carácter, por ejemplo "8.”, 
dependiendo del ordenador que se emplee. Excepto el Sin- 
clair QL que usa el “2”, la mayor parte de los ordenadores 
personales que pueden realizar la concatenación emplean el 
“+”. Veamos el sencillo prógrama correspondiente a la Figura 5: 


199 A$="CAJA” 

110 B$="FUERTE” 

120 C$=A$+B$5:REM CONCATENACION DE 
CADENAS : 

130 PRINT C$ 


RUN 
CAJAFUERTE 
oK 


También es posible formar una cadena a partir de los 
caractres “extraídos” de otra, por medio de las funciones 
LEFT$, RICHT$ Y MID$ (los nombres de las funciones termi- 
nan con “$”, por cuanto restituyen cadenas). 

LEFT$ restituye una cadena constituida por tantos ca- 
racteres como indiquemos de la parte izquierda (en inglés 
left”) de la cadena indicada, tal como ilustra la Figura 6. Vea- 
mos un ejemplo: 


100 A$="JOSE LUIS” 

110 BS=LEFTS(AS,4):REM EXTRAE 4 
CARACTERES 

120 PRINT BS 


RUN 
JOSE 
Ok 


RICHT$ hace exactamente lo mismo, pero por la parte 
derecha (“right”, en inglés) como se ve en la Figura 7, que 
equivale a: 


100 A$="JOSE LUIS” 
119 BSERIGHTS (AS, 4) 
120 PRINT BS 


RUN 
LUIS 
Ok 


La función MID$ extrae un número especificado de ca- 
racteres, a partir de la posición dada, como muestra el si- 
guiente ejemplo (correspondiente a la Figura 8): 


100 A$="JOSE LUIS” 

110 BS=MID$(A$,2,7):REM EXTRAE 7 
CARACTERES APARTIR DEL 2 

120 PRINT BS 


RUN 
OSE LUI 
Ok 
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A$ 
REED » ) EREE 


1] Fig. 6.—La función LEFTS extrae caracteres de la parte izquierda de 
la cadena. 


A$ 
Asta d 


MN Fig. 7—RIGHTS extrae caracteres por la derecha de la cadena. 


) PEEL] 


A$ 
DOSBADODS Y) 


Fig. 8.—MIDS toma los caracteres que le digamos a partir de uno 
dado. 


Como podemos ver, el primer número especifica el ca- 
rácter desde el que se parte, inclusive y el segundo es el 
número de caracteres a extraer. El primer carácter de una 
cadena es el número uno. 

Escribamos ahora un programa que "vuelque” una ca- 
dena, cambiando el orden de sus caracteres. Podemos ha- 
cerlo extrayendo los caracteres, uno a uno, desde el final 
de la cadena inicial y añadiéndolos sucesivamente a la nue- 
va cadena. Para hacerlo, no obstante, tenemos que saber 
cuántos caracteres han de extraerse, es decir, la longitud de 
la cadena. 

La longitud de una cadena se puede conocer con la fun- 
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ción LEN, que proporciona el número de caracteres conte- 
nidos en la cadena. Por ejemplo: 


PRINT LEN ("ABELARDO”) 
8 


(Recordemos que cuando no ponemos número de línea la 
sentencia se ejecuta directamente). 
De esta forma el listado sería: 


100 A$="ROMA" 

110 L=LEN(AS) 

120 FOR I=L TO 1 STEP -1 
130 BF=B$+MID$(4$,1,1) 
140 NEXT 1 

159 PRINT BS 


RUN 
AMOR 
Ok 


Dejamos como ejercicio al lector la comprensión de 
este pequeño programa, aunque forzosamente hemos de re- 
mitirle al estudio del bucle FOR/NEXT del que hablaremos 
en el Capítulo siguiente. 

Si bien estas instrucciones (LEFT$, RIGHT$ y MID$) es- 
tán prácticamente normalizadas, el sinclair QL y el ZX-Spec- 
trum las sustituyen por una propia: la función TO (en inglés 
"2”) que toma todos los caracteres comprendidos entre los 
dos que le demos (inclusives). Por ejemplo (figura 9). 


100 A$="JOSE LUIS” 


110 B$=A$(2 TO 8) 
120 PRINT B$ 


EEELEENE [is] + BERCIAA 
Nerea, ote s 


EN Fig. 9.—Forma en la que trabajan el QL y el ZX-Spectrum con las ca- 
denas. 
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RUN 
OSE LUI 
oK 


produce el mismo efecto que vimos tenía MID$ (A$2,7), 
en este caso. ¿Cómo consigue el equivalente a LEFT$ y 
RIGHT$? Pues mencionando sólo uno de los dos parámetros. 
Así: 


A$ (TO 4) equivaldría al LEFT$ (A$4) que usamos 
antes. 

A$ (6 TO) sería como el RIGHT$ (4$4) del ejemplo 
anterior. 
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ULTIMAS INSTRUCCIONES DE ASIGNACIÓN Y 
ALGUNAS DE CONTROL (SALTOS Y BUCLES) 


Las instrucciones DATA, READ y RESTORE 


as instrucciones DATA, READ y RESTORE 
permiten introducir en el programa listas de 
datos que se leerán de modo análogo a 
como se hacía con una instrucción INPUT, 
que los recibía desde el exterior. 
Estas instrucciones, aunque se comporten 
como las de entrada, son, en realidad, intruc- 
ciones de asignación por cuanto que ope- 
ran solamente en el interior de la memoria del ordenador 
A menudo resulta necesario inicializar las variables; es 
decir, asignarles valores iniciales definidos. Esto se puede 
conseguir con facilidad mediante secuencias de instruccio- 
nes del tipo: 


10 A = 230 
20B=40 
30 C = 155 
40D= 12 
50 E = 130 
60 F = 18 
710G=2 

80 H = 760 
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DESDE EL 
PROGRAMA 
READ/DATA 


¿DATOS? 


POR TECLADO 
INPUT 


A A A 


Fig. 1.—Cuando el ordenador necesita datos puede tomarlos bien 
desde el teclado (INPUT) o del propio programa READ/DATA 


La instrucción DATA permite, por el contrario, reunir to- 
dos los datos en un solo punto del programa (normalmente 
al principio o al final), de forma que son más legibles: 


10 DATA 230, 40, 155, 12, 130, 18, 2, 760 


La instrucción READ (lee) es equivalente a la INPUT, 
con la diferencia de que los datos no se leen desde el te- 
clado, sino en las líneas de la instrucción DATA. Por consi- 
guiente se puede escribir: 


120 READ A, B,C,D, E,F, G,H 


y los ocho valores anteriores se asignarán a las variables co- 
rrespondientes. j 

Veamos un sencillo ejemplo de su utilización: una agen- 
da telefónica. Puesto que todavía no hemos hablado de 
cómo grabar y releer datos a partir de una cinta o de un dis- 
co, podemos tener los datos en el propio programa. 
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5 REM JOOIOOIOROIOR PIO ROO OOROIOROIOROIOROROROKOK 

10 REM X* AGENDA TELEFONICA Xx 

20 REM FOO ORBIOROOROOIO BIO RORORORGÍOIOIOROROIÓR 

30 INPUT "NOMBRE ”:;NOMBRES: IF NOMBRES=" 
” THEN END 

40 RESTORE 

50 READ A$,TES 

60 1F A$="FINAL DE AGENDA” THEN PRINT úl 
NO ESTA SU TELEFONO”:GOTO 39 

70 IF AS<>NOMBRES THEN GOTO 30 

80 PRINT "EL TELEFONO DE ”¡NOMBRES;" ES 
y "+TES:GOTO 39 


1000 REM XXXRXKX XX XX XXX 

1001 REM * AGENDA K 

1902 REM IOGOIGIOIOIOOOGIO.ONE 

1010 DATA "INGELEK”,"2505820" 
1920 DATA ”CASA”, "2022122" 
1030 DATA ”BANCO”, "7383829" 
1948 DATA INFORMACION”, "093" 
9000 REM IGOOOOIOOOGOIOIOIODOONN 
9801 REM X FINAL DE AGENDA k 
JO2 REM AGO ROOIOIOOIOIOIOOIOJDION A 
9019 DATA "FINAL DE AGENDA”,” ” 


RUN 

NOMBRE? INGELEK 

EL TELEFONO DE INGELEK ES: 2503828 
NOMBRE? JOSE LUIS 

NO ESTA SU TELEFONO 

NOMBRE ? 

OK 


En primer lugar, podemos observar que los nombres y 


los números de teléfono se introducen en forma de cadenas 
contenidas en líneas de DATA (se puede continuar a volun- 
tad introduciendo nombres y teléfonos después de la línea 
1040) que se guardan junto con el propio programa (forman 
parte de él en realidad). 


Al dar RUN el programa se inicia pidiendo (línea 30) el 


nombre de la persona cuyo número telefónico queremos Co- 
nocer, asignándolo a la variable NOf$ En este punto, la ca- 
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dena NO$ se compara con la cadena nula (*): si nos limita- 
mos a teclear CR, el programa ejecutará una instrucción END 
y terminará. 

La línea 40 ejecuta una instrucción RESTORE, que lleva 
al comienzo de los DATA, la lectura de las instrucciones, 
READ. En nuestro caso, lleva a la línea 1010, en donde se en- 
cuentra la primera instrucción DATA. La instrucción RESTO- 
RE es necesaria, porque la agenda se lee desde el principio. 

La línea 50 lee dos cadenas, situadas en las dos prime- 
ras sentencias DATA que halle "INGELEK” y "2505820" res- 
pectivamente) asignándolas a las variables A$ y TE$. Des- 
pués de esta operación, el puntero de las instrucciones 
DATA se habrá desplazado, es decir, la siguiente instruc- 
ción READ leerá a partir de la primera constante DATA to- 
davía no usada. 

La línea 60 verifica si, a fuerza de leer instrucciones 
DATA, hemos llegado a la última ("FINAL AGENDA”, línea 
9010). 

En este caso, advierte que el nombre no está en la age- 
da y vuelve al comienzo (línea 30). La línea 9010 contiene 
también una cadena nula ("”), para evitar errores en la lec- 
tura de la última variable TE$ en la línea 50. 

La línea 70 compara el nombre buscado con el leído en 
DATA; si no coinciden, va a la línea 50 en donde se lee el 
siguiente. 


Ae Fig. 2. —Funcionamiento de las instrucciones READ, DATA y RESTO- 
RE en el programa. 
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A la línea 80 se llega solamente si coincidían ambos 
nombres; de ser así, se imprimirá el número de teléfono. 

Unas cuantas precisiones. A efectos del ordenador da 
lo mismo que los valores del DATA vayan en una única lí- 
nea o en más, y que sean o no contiguos. Cuando ejecute 
un READ y se acaben los datos del DATA que estuviera le- 
yendo busca la siguiente línea DATA y trabaja con ella. El 
RESTORE, por su parte, lo que hace es obligar a que el or- 
denador tome la primera línea de programa donde aparez- 
ca un DATA como línea de trabajo para los READ a partir 
de ese momento. 


Instrucciones de control 


La cuarta familia de instrucciones (ver capítulo 3) com- 
prende aquellas que modifican el orden de ejecución de las 
líneas de un programa. El ordenador no está obligado a eje- 
cutar siempre sucesivamente y en el mismo modo las líneas 
del programa y, por consiguiente, puede adaptarse a situa- 
ciones imprevistas. 

Es casi superfluo destacar que se trata de las instruc- 
ciones, desde el punto de vista lógico, más importantes (y 
delicadas).El arte de la programación depende en gran par- 
te de la capacidad de servirse de saltos y bucles (cálculos 
iterativos). Las instrucciones de este grupo son las siguien- 
tes: 

O salto incodicional GOTO 


O salto condicional IF/THEN (ELSE) 
O bucle repetitivo FOR/ NEXT 


En este grupo se podrían incluir también la instrucción 
de salto a un subprograma o subrutina GOSUB, y las de sal- 
to según un valor (ON GOTO y ON GOSUB), pero de ellas 
hablaremos en el siguiente volumen de la B.B.1 dedicado al 
BASIC. 


Salto incondicional GOTO 


Esta instrucción hace que la ejecución del programa 
prosiga a partir de la línea que le indiquemos y no de la in- 
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mediatamente sucesiva. Por ejemplo, al final de un progra- 
ma podemos escribir GOTO a su línea de comienzo para vol- 
ver a ejecutarlo desde el principio. 


10 PRINT "CALCULO DE UN PRODUCTO” 
20 INPUT "DAR DOS NUMEROS";A,B 
39 P=AXB 

40 PRINT "EL RESULTADO ES:"¡P 

30 GOTO 10 

50 END 


Sin la línea 50, el programa, después de haber impreso 
el resultado de un producto, se pararía (END). Por el con- 
trario, GOTO 10 le hace saltar a la línea 10 y repetir el pro- 
grama. Si en lugar de GOTO 10 ponemos GOTO 20, ya no 
se volverá a imprimir el mensaje inicial CALCULO DEL PRO- 
DUCTO. 

Ojo con este uso del GOTO, pues si obligamos a un pro- 
grama a repetirse de este modo, ya no tendrá un final lógi- 
co y por consiguiente, proseguirá ejecuntando multiplica- 
ciones indefinidamente. Para parar el ordenador, será pre- 
ciso actuar desde fuera del programa y pulsar una de las te- 
claks especiales, tales como Break, Stop o Control C. Por lo 
tanto los bucles sin fin que puede originar el GOTO, que 
por sí mismos no están prohibidos, se utilizan solamente en 
casos muy especiales, 

La figura 3 muestra el diagrama de bloques de este pe- 
queño programa. Se ve como el programa está cerrado en 
un anillo sin ninguna posibilidad de terminar “de forma es- 
pontánea”. 


Saltos condicionales IF/THEN (ELSE) 


La instrucción GOTO es muy rígida y permite efectuar 
solamente saltos fijos en el programa. Por el contrario, las 
instrucciones de salto condicional permiten realizar saltos, 
o ejecutar grupos completos de instrucciones si una cierta 
condición es verdadera. Veamos un ejemplo: 


10 INPUT "ESCRIBE UN NUMERO MENOR QUE Y 
“in 


E Fig. 3—Diagrama de bloques de un programa sin salida 


20 IF N>=9 THEN GOTO 10 
30 PRINT "BRAVO,HAS ACERTADO” 


La instrucción 20 se lee como sigue: si N es mayor o 
igual que 9, pasar a la línea 10. Si tecleamos, por ejemplo, 
15, al ser mayor que 9 la “condición” será verdadera y se 
producirá el salto del programa. 

A modo de inciso, recordamos que el símbolo > quiere 
decir “mayor que” mientras que >=significa "mayor o igual 
que”. El símbolo < quiere decir "menor que” y el <= signi- 
fica “menor o igual que”. 

Por el contrario, si tecleamos un número menor que 9,. 
tal como 5, será falsa la condición y el programa sigue en 
la línea 30 en donde se imprimirá el mensaje "BRAVO, HAS 
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10 Fig. 4. —Diagrama de bloques de un programa con salto condicional. 


ACERTADO”. En la Figura 4 se ilustra el diagrama de blo- 
ques correspondiente. 

Son poquísimas las versiones del BASIC que permiten 
solamente el IF. THEN GOTO (que además suelen expresar 
IF. GOTO). La mayor parte permiten una forma más flexible 
que admite no solamente el salto condicional, sino también 
la ejecución condicional de una o más instrucciones. Vea- 
mos un ejemplo: 


10 INPUT ” DAME UN NUMERO” ;N 
20 QsNAN(REM CALCULO DEL CUADRADO 
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39 PRINT "CUAL ES EL CUADRADO DE "¿N 
40 INPUT XIREM TENTATIVA 
50 1F X<Q THEN PRINT "DEMASIADO BAJO!” 


GOTO 30 

690 IF X> THEN PRINT "DEMASIADO ALTO!” 
GOTO 30 

79 PRINT “HAS ACERTADO,ERA ”/Q 


El programa pide un número (N) y calcula su cuadro 
(Q). A continuación, pide otro número (X), que representa 
una tentativa de adivinar el cuadrado de N. 

En este punto (línea 50) se comprueba si el punto intro- 
ducido es menor que el valor a adivinar. Si lo fuera, ENTON- 
CES (en inglés THEN) se ejecutará todo el resto de la línea 
50. Si no lo fuera, se saltará el resto de la línea y proseguirá 
con la siguiente línea (60). 

Lo anterior se denomina ejecución condicional de una 
instrucción (en nuestro caso, de dos instrucciones, una de 
ellas PRINT y la otra GOTO), por cuanto que las instruccio- 
nes se ejecutan solamente si la condición es verdadera. 

En la línea 50 después del THEN, hay dos instrucciones, 
separadas por el símbolo "” (dos puntos). En el lenguaje BA- 
SIC, las instrucciones separadas por dos puntos se ejecutan 
una después de la otra, como si estuvieran en líneas suce- 
sivas (casi cualquier versión del lenguaje BASIC lo permite, 
aunque alguna emplea un símbolo diferente). Habida cuen- 
ta de que ambas instrucciones se encuentran después del 
THEN en la misma línea, se ejecutarán ambas (si la condi- 
ción es verdadera) o no se ejecutará ninguna (si la condi- 
ción es falsa). 

El efecto sobre el programa ejemplo es que, si el nú- 
mero introducido (X) es menor que la solución (Q), se im- 
primirá un "DEMASIADO BAJO'” y se ejecutará una instruc- 
ción GOTO 30, que solicita el valor de una nueva tentativa. 
Si el námero no es menor que la solución (por consiguiente 
es igual o mayor), el programa ignorará completamente el 
resto de la línea 50. 

En la línea 60 todo es como antes con la diferencia de 
que lo que se comprueba es si el número es mayor que el 
resultado. Si fuera así, se producirá el mensaje correspon- 
diente y el retorno a la línea 30. j 

Finalmente, si el número no es mayor ni menor que el 
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EN Fig. 5.—Diagrama de bloques de “Adivina el cuadrado”. 
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resultado, deberá ser igual y la respuesta es exacta. En este 
caso, se generará el mensaje y finalizará el programa (línea 
70). 

Observe como la misma instrucción PRINT puede im- 
primir, por ejemplo, una cadena (encerrada entre comillas) 
e inmediatamente (con punto y coma) el valor de una va- 
riable numérica. 

La figura 5 ilustra el diagrama de flujo de este progra- 
ma. Determinadas versiones de BASIC permiten que en lu- 
gar de escribir, por ejemplo, IF N> = 9 THEN GOTO 10 se 
ponga IF N> = 9 THEN 10 o bien IF N> = 9 GOTO 10. 


IF/THEN 


] Fig. 6—Analogía de la instrucción IF/THEN. Si se cumple la condi- 


ción (ser camión) ejecutará esa línea, pero si no se cumple la saltará. 
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En muchos ordenadores se admite una extensión del 
IF/THEN: el IF/THEN/ELSE muy parecido al anterior. Si la 
condición es cierta el programa realiza las instrucciones que 
encuentra antes del ELSE y luego salta las instrucciones de 
éste. Si es falsa, las instrucciones ejecutadas son las del ELSE 
y el programa continua después normalmente. 

Veamos un ejemplo: 


100 INPUT "DAME TU CLAVE”; CL 

110 IF (CL=327) THEN PRINT “CLAVE 
CORRECTA”:GOTO 200 ELSE PRINT “NO 
ES ESA” END 

209 GOTO 200 


RUN 
DAME TU CLAVE? 134 
HE ES ESA 


Si la clave es correcta el programa lo dice y continua. 
En otro caso, tras avisarlo, se acaba. 


Expresiones lógicas 


Hemos hablado ya de expresiones matemáticas y de 
operaciones con cadenas. En BASIC existen también "expre- 
siones lógicas” que se emplean sobre todo en las instruc- 
ciones condicionales IF/THEN. 

Vimos como en las instrucciones IF/THEN la(s) senten- 
cia(s) a ejecutar dependen de una condición. Con gran fre- 
cuencia, esta condición puede ser una expresión lógica 
completa, cuyo resultado se utiliza a fin de realizar la elec- 
ción, 

Una expresión lógica, como una expresión algebraica 
normal, está constituida por "operandos” y “operadores”. Por 
ejemplo, en la expresión algebraica A + 3, A y 3son los ope- 
randos y "+" es el operador, En las expresiones lógicas, el 
resultado puede tomar solamente los valores verdadero o 
falso. Los operadores en las expresiones lógicas del BASIC 
son los operadores de relación y los operadores lógicos. 

Los primeros (de relación) son operadores, vistos ya 
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con anterioridad, que nos informan de si dos números son 
entre si iguales o uno es menor, o mayor que el otro. Por 
ejemplo 5>3 es una expresión verdadera, mientras que es 
falsa 5<=10, La expresión con variables A<=5 puede ser ver- 
dadera o falsa, según el valor tomado por A. 

En los ordenadores se pueden emplear los operadores 
de relación también con las cadenas. Así podemos escribir 
la expresión B$ = P$ su valor será verdadero si las dos ca- 
denas son iguales y falso en caso contrario (no ha de con- 
fundirse con la instrucción de asignación LET B$=P$ que, 
aunque pueda escribirse Bf=P$ constituye por sí misma una 
instrucción completa, en tanto que el operador relacional se 
usa durante el curso de una decisión —por ejemplo en una 
instrucción IF/THEN). 

De modo similar, se pueden escribir también expresio- 
nes tales como: A$<B$ o Cf<=Df En tal caso, se comprueba 
si una cadena precede a otra alfabéticamente (como en un 
diccionario). Del mismo modo que PEDRITO "es mayor” que 
CARLOS porque le sigue en orden alfabético, se pueden cal- 
cular expresiones de relación entre cadenas cualesquiera. 

El criterio que permite poner en orden cadenas que in- 
cluyan cualquier carácter es el que se deduce del código 
ASCIL Así, la cadena “2A” precede a “ABC” porque en el có- 
digo ASCII el 2 está codificado antes que la letra A. Para los 
datos alfabéticos se sigue, en la práctica, el criterio adopta- 
do por todos los vocabularios. 

Los operadores lógicos trabajan con valores lógicos y 
proporcionan un resultado que también lo es. Los operado- 
res de uso más frecuente en el BASIC son AND, OR y NOT. 


O AND es el operador del producto lógico. A ANDB es una 
expresión verdadera solamente si A y B son ambos ver- 
daderos y en los demás casos será falsa, 

O OR es la suma lógica. A OR B da el resultado de verda- 
dero si es verdadero A, o B, o ambos a la vez. Proporcio- 
nará el resultado de falso si A y B son, a la vez, falsos. 

O NOT es la negación lógica. NOT A invierte el valor lógi- 
co de A de verdadero a falso o viceversa. 


Veamos un pequeño ejemplo para comprender cómo | 
se utilizan las expresiones lógicas en un programa lo pode- 
mos hacer pidiendo al ordenador que nos indique los nú- 
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meros comprendidos entre 10 y 20, elegidos entre aquellos 
que damos libremente a la entrada: 


19 INPUT ” DAME UN NUMERO CUALQUIERA”;N 
20 IF (N>=10) AND (N<=20) THEN GOTO 50 
30 dll "ESE NUMERO NO ESTA ENTRE 10 Y 
49 GOTO 10 

30 PRINT ” ESE NUMERO ESTA ENTRE 19 Y 


609 GOTO 10 


Instrucciones de bucle: FOR/NEXT 


Una de las situaciones más frecuentes que se nos pre- 
sentan al escribir un programa es aquella en la que debe- 
mos repetir muchas veces un conjunto de instrucciones. Vi- 
mos ya anteriormente la “realidad” de este problema cuan- 
do queríamos cargar los datos en un vector o bien extraer 
“al contrario” los caracteres de una cadena. 

Supongamos que en un vector A$ de 100 elementos se 
tengan que cargar 100 nombres. No es admisible escribir 
100 instrucciones INPUT. Por ello, el BASIC pone a nuestra 
disposición el par de instrucciones FOR/NEXT que resuel- 
ve el problema con una sola instrucción INPUT. Veamos 
como lo hace 


10 DIM A$5(190) 
20 FOR K=1 TO 100 
30 NEXT K 


La instrucción 10 la conocemos ya y es la que dimen- 
siona a 100 el vector de cadenas A$ Las instrucciones 20, 
30 y 40 se leen como sigue: para K variando desde 1 a 100 
(1, 2, 3, etc), ejecuta la instrucción INPUT del elemento K-é- 
simo del vector A$ 

La instrucción FOR tiene una variable y tres parámétros 
que actúan sobre ella. El primero es el valor inicial del bu- 
cle y de la variable por tanto, (en nuestro caso K=1), el se- 
gundo es el extremo del bucle (en el ejemplo dado, 100) y 

el tercero (que aquí no hemos utilizado, pero que se vio en 
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el ejemplo incluido al final del capítulo 4), es el paso o in- 
cremento del bucle (STEP); cuando no se explicita, el BA- 
SIC hace STEP=1. 

En lugar de incrementar K de uno en uno se podría in- 
crementar en un valor predeterminado. Por ejemplo, si qui- 
siéramos cargar solamente los elementos de posición impar 
de A$, podríamos cambiar así la instrucción 20: 


20 FOR K=1 TO 100 STEP 2 


En tal caso, K tomaría sucesivamente los valores 1, 3, 5, 
etc, Si el parámetro del paso STEP no se utiliza, la variable 
de bucle (K en este ejemplo) se incrementará en uno. 

Es posible también recorrer un bucle al revés (vea, de 
nuevo, el ejemplo final del Capítulo 4). En tal caso, el pará- 
metro STEP deberá tomar un valor negativo. 

Cargemos nuestro vector de nombres (A$) al revés. 


19 DIM A$(100) 

20 FOR K=109 TO 1 STEP -1 
30 INPUT A$(K) 

40 NEXT K 


La variable de bucle K toma los valores 100, 99, 98, etc, 
hasta 1. 

Las instrucciones de bucle FOR/NEXT pueden ponerse 
una dentro de otra. Este modo de utilizarlas se denomina, 
en la jerga «anidamiento de bucles». Ponemos de manifies- 
to el anidamiento de dos bucles, con un ejemplo, muy sen- 
cillo pero eficaz, que es la elaboración de una tabla pitagó- 
rica. 


REMO AGOCOOOICIOOIOOOOODODOONR 
19 REM * TABLA PITAGORICA A 
1 REM IRGOOOIOIOIOIOIOIOIOOGOIOIGIOIODK 
20 FOR 1=1 TO 10 

30 FOR J=1 TO 10 

40 PRINT IXJj" ”; 

30 NEXT Y 

60 PRINT 

79 PRINT 

80 NEXT 1 
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Las instrucciones 30, 40, y 50, constituyen el bucle inte- 
rior, que calcula e imprime una línea de la tabla con el ín- 
dice l, que se mantiene constante, y el índice J que varía des- 
de 1 hasta 10. Observe que la instrucción PRINT en la línea 
40 termina con un punto y coma (;) para no saltar una línea 
durante la escritura de una fila. 

Para cada línea se repite el mismo ciclo con un valor 
diferente de 1. El bucle exterior (en el que varía 1) hace re- 
petir diez veces todo el bucle interior (en el que varía J). La 
instrucción PRINT en la línea 60 sirve para saltar una línea 
al final de cada una de ellas. Probemos a ejecutar el progra- 
ma y se obtendrá el resultado ilustrado en la Figura 7. 

¿Por qué la tabla no está exactamente alineada? Deja- 
mos al lector encontrar la respuesta, con la ayuda de la ins- 
trucción: 


45 IF IXJ<10 THEN PRINT ” ”j; 


18 27 36 45 34 63 72 Bi Ye 
10 20 30 s“e 53504 69 70 88 ye 100 


Fig. 7—Cómo aparece la tabla de números generada por el progra- 
ma “Tabla pitagórica” 
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que pone todo en su lugar, como se ve en el siguiente lis- 
tado y ejecución. 

Para que un anidamiento de bucles sea correcto es im- 
prescindible que ningún NEXT se encuentre entre dos FOR 
sin completar (sin llegar a su NEXT). Por tanto el orden en 
que se encuentren los NEXT debe coincidir con el que usa- 
mos para escribir los FOR (ver Figura 8). 


Un programa-resumen: «Archivo con punteros» 


Para completar este primer volumen sobre el BASIC, 
consideramos oportuno proponerles un programa un poco 
más completo que los habituales ejemplos que hemos ido 
viendo y que, si se enriquece con las instrucciones para el 
empleo de casete o de disco flexible, puede resultar verda- 
deramente útil. Se trata de un archivo de nombres que los 
mantiene automáticamente en orden alfabético. 

En los capítulos anteriores, no tuvimos ocasión de ha- 
blar de archivos o ficheros (lo trataremos en el segundo vo- 
lumen del BASIC) ni de sus operaciones normales de con- 
trol como, por ejemplo, ordenar sus elementos por orden al- 


E) O) (o) 


FOR 1= FOR l= FOR 1= 
FOR J= FOR J= 
FOR J= 
[ FOR K= [ FOR K= 
NEXTK= NEXT 1= NEXT K= 
NEXT J= NEXT I= 
NEXT J= 
NEXT I= NEXT J= 
Fig. 8.—Ejemplo correcto (a) e incorrectos (b, c) de anidamiento de 
bucles. 
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fabético, añadirles otros nuevos, anular alguno de los anti- 
guos, etc. 

Pues bien, el programa que les proponemos pretende, 
precisamente, actuar como un archivo, con sus característi- 
cas instrucciones de control. 

El primer problema que se presenta, al tratar los archi- 
vos, es el de ordenarlos (en inglés, «sort»). El orden más sim- 
ple que se puede considerar es el alfabético, pero vimos 
ya, al hablar de los operadores relacionales, que este con- 
cepto puede extenderse también a otros caracteres toman- 
do como referencia el código ASCII. De este modo, se pue- 
den poner en orden los códigos de los productos de una 
empresa, tanto los que contengan letras como los que po- 
sean dígitos u otros caracteres. 

No queremos adentrarnos ahora en las técnicas de or- 
denación, pero se puede intuir con facilidad que para orde- 
nar una serie de datos es necesario que el ordenador gaste, 
a veces, mucho tiempo (indudablemente, subirá su valor 
con el del número de datos a ordenar). Uno de los criterios 
más sencillos de ordenación, por ejemplo, procede de ma- 
nera repetitiva, extrayendo el elemento más pequeño (o 
más grande) de toda la serie, luego el menor (o mayor) de 
los que quedan y así sucesivamente. Al decir extraer que- 
remos significar que toma su valor y lo escribe en otra par- 
te. 

Ahora bien, estas operaciones de reescritura pueden 
ser muy costosas; piense, por ejemplo en los datos de ar- 
chivos complejos como los de un registro civil. Mientras se 
trate de realizar ejercicios en un ordenador personal y se 
ordenen pocos registros, (así se llaman en informática los 
elementos de un archivo o fichero) todos los algoritmos van 
bien, pero cuando entremos en trabajos «comprometidos», 
es preciso estar muy atentos a ahorrar tiempo evitando, por 
ejemplo, inútiles reescrituras de datos. 

El ejemplo que proponemos crea, y mantiene ordena- 
do, un fichero de nombres sin reescribir nunca ningún nom- 
bre, teniendo solamente en cuenta una sucesión de punte- 
ros. p 

Los punteros son un tipo particular de variables que re- 
lacionan entre sí los elementos de una lista. Contienen siem- 
pre el valor de una dirección, de ahí su nombre, pues «apun- 
tan» hacia esa dirección. Con este sistema el primer elemen- 
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to contiene, además de sus datos, un puntero dirigido al se- 
gundo elemento; éste contiene otro puntero dirigido al ter- 
cero y así sucesivamente. En la Figura 9 vemos cómo se pre- 
senta una lista de elementos vinculados entre sí por punte- 
ros y como entrará entre el primer y segundo elementos de 
la lista otro nuevo. 

Recordemos que ahora cada elemento tiene dos conte- 
nidos: el dato y su puntero, que señala al elemento siguiente. 

La utilidad de los punteros se comprende inmediata- 
mente considerando, por ejemplo, que para insertar un nue- 
vo elemento en la lista basta con adaptar los punteros (Fi- 
gura 9). 

El programa «Archivo» (Figura 10) puede desempeñar 
tres funciones: insertar nuevos elementos (1), leer los nom- 
bres (L) y leer, además de los nombres, sus punteros (P). 

El archivo está contenido en los vectores N$ y P, dimen- 
sionados en la línea 140 a 50, pero podría tener cualquier lon- 
gitud o, mejor todavía, estar grabado en casete o disco. 


a) 


AREA — 


(Dato nuevo) 


Fig. 9.—Funcionamiento de los punteros (a) y ejemplo de inserción 
en una lista (b). 
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602 
610 


REM ROO ROOOOOOIOOOOOOOOOOOOIOIOIOIOIOIOIGIOOON 
REM X ARCHIVO ORDENADO CON PUNTEROS XK 
550 MOJORORRIOROROROOIGIOOOOIOIOROOIGIOOIOIOIOIGIO/DOIODIODIONK 
REM 

DIM NS (50) ,P (50) 

REM 


A PRIMER PUNTERO LIBRE 

PRINT ¿¡PRINT "QUE OPERACION DESEA?” 
PRINT ” INSERCIONES <I> ” 
PRINT " LEER NOMBRES ELA ” 
PRINT ” NOMBRE Y PUNTERO <P> " 
REM 

INPUT R$ 

IF R$="I"” THEN GOTO 490 

IF R$="L” THEN GOTO 609 

IF R$="P" THEN GOTO 8009 

GOTO 240 

REM 

REM OGIOIOIOROOOOOOOROIOORODODOOOON 

REM X INSERCION DE NOMBRES — * 

REM OOOO 

REM 

PRINT 

INPUT "NOMBRE”;¡NS;1F N$=”" THEN GOTO 180 
PR =P(1) 

PE=1 ¡REM PE=PUNTERO DE EXPLORACIÓN 
IF PR=9 THEN GOTO 530 


REM 
IF NS(PR)>N3 THEN GOTO 530 
PE=PR 


PR=P (PR) 

GOTO 439 

REM 

P(PL)=PR 

P(PE)=PL 

NS(PL)=NS 

PL=PL+1 

GOTO 420 

REM 

REM IGIOIOIGOOOODOOROROGOROODORGODER 
REM X LECTURA DE NOMBRES — *X 
REM GIRO OIOIOOOIOIOOOIOIOIOOOOOORK 
REM 


E Fig. 10.—Programa “Archivo” y ejecución. 
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6290 PRINT 

639 PR=P(1) 

649 REM 

630 IF PR =9 THEN GOTO 180 
660 PRINT NS(PR) 

670 PR=P(PR) 

680 REN 650 


EM 
900 REM IAOIOIOROIOIOIODIOOOOOIOIOIOJOIDIOGIOIOIOIOODK 
801 REM * LECTURA DE NOMBRES Y PUNTEROS KR 
UE REM GOO GOOIOOODIODIOIGIOIGOOIDOLK 
EM 


820 PRINT 

830 FOR K=1 TO PL 

840 PRINT K,NS(K),P(K) 
850 NEXT K 

860 GOTO 1809 


RUN 

QUE OPERACION DESEA? 
INSERCIONES <1> 
LEER NOMBRES Sl 
NOMBRE Y PUNTERO <P> 

¡38 


NOMBRE? FERNANDO 
NOMBRE? CARLOS 
NOMBRE? EMILIO 
NOMBRE? ANTONIO 
NOMBRE? VICENTE 
NOMBRE? MARIANO 
NOMBRE? ENRIQUE 


NOMBRE ? 

QUE OPERACION DESEA? 
INSERCIONES <I> 
LEER NOMBRES <L> 


a ia Y PUNTERO <P> 


1. 10.—Continuación del programa “Archivo”. 


ANTONIO 
CARLOS 
EMILIO 
ENRIQUE 
FERNANDO 
MARTANO 
VICENTE 


QUE OPERACION DESEA? 
INSERCIONES <I> 
LEER NOMBRES <L> 
NOMBRE Y PUNTERO PI 


- 
TU 


FERNANDO 
CARLOS 
EMILIO 
ANTONTO 
VICENTE 
MARTANO 
ENRIQUE 


0 0 ym y au 
9 NOS yn + — On 


QUE OPERACION DESEA? 
INSERCIONES £1> 
LEER NOMBRES <L> 


NOMBRE Y PUNTERO <P> 
? 


E Fig. 10—Continuación del programa “Archivo”. 


El vector N$ contiene los nombres, mientras que el vec- 
tor P contiene los punteros correspondientes. Lo que hay 
que tener bien presente es que los nombres no se despla- 
zarán nunca en el array cuando se inserte alguno nuevo y 
se haga la ordenación; serán únicamente los punteros los 
que se modifiquen. 

Para comprender cómo se comportan los punteros, ob- 
serve primero cómo se produce la lectura del archivo or- 
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denado (opción L del menú) en lás líneas del programa des- 
de la 600 a la 690. Se comienza por leer el puntero P (1) en 
la línea 630, si es diferente de cero (final del archivo) se lee 
el nombre N$ (PR), y se toma el puntero correspondiente 
P(PR) que nos servirá para localizar el nombre siguiente y 
así sucesivamente. 

Las líneas del programa desde la 40 a 580 crean el ar- 
chivo insertando nuevos elementos y ajustando los punte- 
ros de modo que los nombres sean legibles en orden alfa- 
bético. La Figura 11 muestra cómo se controlan los punteros, 

Después de haber introducido los nombres ALDO y 
CARLOS, por casualidad ya ordenados, para introducir AN- 


N$ O) PO NS () PO NS () PO 


Después del Después del 
vacio primer nombre segundo nombre 


3| CARLOS 


; Hs 11,—Funcionamiento de los punteros del programa “Archivo”, 
PL es el puntero del elemento libre, PR es el puntero real (hacia ade- 
lante) y PE es la variable para la exploración en el interior del archivo, 


Inserción del 
elemento ANDREA 
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DREA se debe leer en el PL cual es el próximo elemento li- 
bre (4) y actualizar los punteros de los elementos 2 (ALDO) 
y 4 (CARLOS). 

Observe que la única instrucción que compara el orden 
de dos nombres está en la línea 480, pero no se realiza nin- 
gún desplazamiento, sino una actualización de punteros (lí- 
neas 490 y 500) desarrollada de una ingeniosa manera. Para 
la opción P, como verá, usamos un bucle FOR/NEXT. Esto 
es debido a que aquí no nos interesa sacar los nombres por 
orden alfabético, sino tan sólo saber los nombres que hay y 
sus punteros respectivos. 


Despedida 


Este primer volumen sobre el lenguaje BASIC se le ha- 
brá pasado muy rápidamente, en armonía con la sencillez 
que caracteriza el lenguaje. Llegados a este punto, podemos 
tener la seguridad de que vale la pena continuar este reco- 
rrido por el mundo del BASIC, leyendo también el siguiente 
volumen que nuestra Biblioteca Básica Informática le dedi- 
cará. Después de haberlo hecho, podremos afrontar metas 
más difíciles, ayudados además por el resto de los volúme- 
nes de nuestra colección, que irán apareciendo «sin prisas, 
pero sin pausas». Les deseamos un provechoso estudio. 
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EL CODIGO ASCII 


os datos que un ordenador procesa y alma- 
cena en su interior suelen ser datos numé- 
ricos o cadenas de caracteres. El tratamien- 
to de los números no es difícil, por cuanto 
que el ordenador es una máquina electró- 
nica digital y, por consiguiente, puede ma- 
nejar fácilmente los números binarios (cons- 
MORA tituidos solamente por los dígitos O y 1). Ya 
que as los números, incluso los decimales comunes, se 
pueden convertir fácilmente en forma binaria (ver el núme- 
ro 1 de la B. B. 1.) siempre será posible almacenarlos en los 
ordenadores. Evidentemente, en cualquier ordenador per- 
sonal estas operaciones de transformación en código bina- 
rio se realizan de forma automática, por lo que quien pro- 
grama no debe preocuparse en absoluto de ellas. 

Almacenar caracteres (letras, signos de puntuación, dí- 
gitos, etc) será pues bastante fácil si antes los hemos con- 
dificado adecuadamente. A cada carácter, letra, etc, hace- 
mos corresponder un número binario que se almacenará 
luego como los demás. 

Las posibilidades de relacionar números y caracteres 
son muy numerosas. La más frecuentemente utilizada en los 
ordenadores personales es la codificación americana ASCIL 
La palabra ASCII es la abreviatura de «American Standard 
Code for Information Interchange», que significa «Código 
americano para el intercambio de información». El código 
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ASCII, aceptado universalmente no sólo en los ordenadores 
personales, permite codificar 128 caracteres. A menudo se 
extiende a 256 caracteres para utilizar un byte completo (un 
byte está constituido por 8 bits y 2% =256), lo que permite 
incluir algunos caracteres pseudográficos o de control adi- 
cionales. 

La tabla siguiente indica los 128 primeros caracteres del 
código ASCII estándar (incluido el cero). 


CODIGO ASCII 


CA- CODIGO 

RAC- = Ñ DEFINICION 

TER BINARIO DECIMAL HEXADECIMAL 

NUL 0000 0000 0 00 Nulo 

SOH 0000 0001 1 01 Principio de encabezamien- 
to 

STX 0000 0010 2 02 Comienzo de texto 

ETX 0000 0011 3 03 Fin de texto 

EOT 0000 0100 4 04 Fin de transmisión 

ENQ 0000 0101 5 05 Pregunta 

ACK 0000 0110 6 06 Acuse de recibo 

BEL 0000 0111 7 07 Timbre (señal) 

BS 0000 1000 8 08 Retroceso 

HT 0000 1001 9 09 Tabulación horizontal 

LF 0000 1010 10 0A Cambio de renglón 

VT 0000 1011 11 OB Tabulación horizontal 

FF 0000 1100 12 019 Página siguiente 

CR 0000 1101 13 0D Retorno de carro 

so 0000 1110 14 OE Fuera de código 

SI 0000 1111 15 OF En código 

DLE 0001 0000 16 10 Encaje de transmisión 

DC1 0001 0001 17 ar Mando de dispositivo auxi- 
liar 1 

pDc2 0001 0010 18 12 Mando de dispositivo auxi- 
liar 2 

DC3 0001 0011 19 13 Mando de dispositivo auxi- 

: liar 3 

DC4 0001 0100 20 14 Mando de dispositivo auxi- 
liar 4 

NAK 0001 0101 21 15 Acuse de recibo negativo 

SYN 0001 0110 22 16 Sincronización , 

ETB 0001 0111 23 17 Fin de bloque de transmi- 
sión 

CAN 0001 1000 24 18 Cancelación 

EM 0001 1001 25 19 Fin de medio físico 


CODIGO ASCII 


CA- CODIGO 
RAC- DEFINICION 
TER BINARIO DECIMAL HEXADECIMAL 
SUB 0001 1010 26 14 Sustitución 
ESC 0001 1011 27 18 Escape 
FS 0001 1100 28 10 Separador de fichero 
GS 0001 1101 29 1D Separador de grupo 
RS, 0001 1110 30 1E Separador de registro 
US 0001 1111 31 1F Separador de unidad 
0010 0000 32 20 Espacio en blanco 
| 0010 0001 33 21 Admiración 
ta 0010 0010 34 22 Comillas 
H 0010 0011 35 23 Símbolo número (cancela) 
$ 0010 0100 36 24 Símbolo dólar 
% 0010 0101 37 25 Porcentaje 
8 0010 0110 38 26 “Ampersand” 
0010 0111 39 27 Acento 
( 0010 1000 40 28 Apertura de paréntesis 
) 0010 1001 41 29 Cierre de paréntesis 
ll 0010 1010 42 2A Asterisco 
+ 0010 1011' 43 2B Signo más 
, 0010 1100 44 2C Coma 
- 0010 1101 45 2D Guión (signo menos) 
, 0010 1110 46 2E Punto 
EA 0010 1111 47 2F Símbolo división (““slash”') 
0 0011 0000 48 30 
1 0011 0001 49 31 
2 0011 0010 50 32 
3 0011 0011 51 33 
4 0011 0100 52 34 
5 0011 0101 53 35 
6 0011 0110 54 36 
7 0011 0111 55 37 
8 0011 1000 56 38 
9 0011 1001 57 39 
: 0011 1010 58 3A Dos puntos 
> 0011 1011 59 38 Punto y coma 
< 0011 1100 60 3C Menor que 
= 0011 1101 61 3D Igual 
> 0011 1110 62 JE Mayor que 
? 0011 1111 63 3F Interrogante 
(0) 0100 0000 64 40 “Atpersand”, arroba 
A 0100 0001 65 41 
B 0100 0010 66 42 
Cc 0100 0011 67 43 
D 0100 0100 68 44 
E 0100 0101 69 45 
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CODIGO ASCII 


CA- CODIGO 

RAC- - o DEFINICION 

TER BINARIO DECIMAL HEXADECIMAL 

P 0100 0110 70 46 

G 0100 0111 71 47 

H 0100 1000 72 48 

| 0100 1001 73 49 

J 0100 1010 74 4A 

K 0100 1011 75 48 

L 0100 1100 76 4C 

M 0100 1101 77 4D 

N 0100 1110 78 4E 

0) 0100 1111 79 4F 

P 0101 0000 80 50 

Q 0101 0001 81 51 

R 0101 0010 82 52 

Ss 0101 0011 83 53 

T 0101 0100 84 54 

U 0101 0101 85 55 

V 0101 0110 86 56 

w 0101 0111 87 57 

Xx 0101 1000 88 58 

Y 0101 1001 89 59 

E 0101 1010 90 5A 

[ 0101 1011 91 5B Apertura de corchete 

XA 0101 1100 92 5C Barra invertida (''Back 

slash”) 

] 0101 1101 93 5D Cierre de corchete 

S 0101 1110 94 5E Acento Circunflejo 

ES 0101 1111 95 5F Guión de subrayado 
0110 0000 96 60 Acento inverso 

a 0110 0001 97 61 

b 0110 0010 98 62 

c 0110 0011 99 63 

d 0110 0100 100 64 

e 0110 0101 101 65 

f 0110 0110 102 66 

g 0110 0111 103 67 

h 0110 1000 104 68 

i 0110 1001 105 69 

j 0110 1010 106 SA 

k 0110 1011 107 68 

l 0110 1100 108 6C 

m 0110 1101 109 6D 

n 0110 1110 110 SE 

0 0110 1111 111 6F 

P 0111 0000 112 70 


— 
o 
Do 


CODIGO ASCII 


CA- CODIGO 

RAC- _— DEFINICION 
TER BINARIO DECIMAL HEXADECIMAL 

q 0111 0001 113 71 

r 0111 0010 114 7 

s 0111 0011 115 73 

t 0111 0100 116 74 

u 0111 0101 117 75 

v 0111 0110 118 76 

w 0111 0111 119 77 

Xx 0111 1000 120 78 

y 0111 1001 121 79 

z 0111 1010 122 7A 

E 0111 1011 123 7B Apertura de corchete 
| 0111 1100 124 7C Barra vertical 

> 0111 1101 125 7D Cierre de corchete 
añ 0111 1110 126 7E Tilde 

DEL 0111 1111 127 7F Borrado, supresión 
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RESUMEN DE LAS INSTRUCCIONES ESTUDIADAS 


ara facilitar al lector la rápida solución de 
cualquier duda sobre la sintaxis de las ins- 
trucciones vistas hemos confeccionado un 
pequeño resumen-diccionario, que espera- 
mos les resulte útil. 

Además de definir la función de la ins- 
trucción y su sintaxis incluye unos cuantos 

E ejemplos de muestra. En ningún caso inclui- 

mos el número de línea, pues damos por sentado que el lec- 
tor sabe que si la instrucción forma parte de un programa 
debe llevarlo y, en caso contrario (ejecución directa), no. 

En las definiciones que siguen usaremos los siguientes 
símbolos: 

[] elemento opcional 

() posibilidades alternativas 

<> deben ser determinados por el usuario. 


ASC 


Devuelve el código ASCII correspondiente al carácter 
dado. Si fuera una cadena da el del primer carácter. 


ASC ((<variable alfanumérica> <"cadena”>)) 


ASC (V$) 
ASC ("P”) 
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CHR$ 


Devuelve el carácter correspondiente al código ASCII 


dado : 
CHR$ (65) 
DATA 


Almacena valores constantes (numéricos o caracteres) 
para que sean leídos mediante READ 


DATA <constante 1> [<constante 2>..] 


DATA "BBI”, 1, 1985 


DIM 
Dimensiona el tamaño máximo de variables con índice 
DIM <variable 1> [,<variable 2>..] 
DIM NOMBRE%(30,7), PE(80), A(3) 


FOR/NEXT 


Ejecuta las instrucciones comprendidas entre ambas 
hasta que la variable de bucle (cuyo valor inicial lo da <ex- 
presión 1>) alcanza, incrementándose a cada pasada en es- 
calones dados por <expresión 3>, por defecto 1, el valor 
de <expresión 2>. l 


FOR <variable bucle>=<expresión 1> TO 
<expresión 2> [STEP <expresión 3>] 


NEXT <variable bucle> 


FOR I=(F-1) TO 5 STEP F 
NEXT 1 


106 


Funciones matemáticas 


Devuelven el resultado de aplicar la función concreta 
correspondiente al dato 


FUNCION DADA (<dato>) 


SQR (8+C) raíz cuadrada 

SIN (0.18*H) seno (ángulo en radianes) 

COS (AMG) coseno (ángulo en radianes) 

TAM (CIRC) tangente (ángulo en radianes) 

ATM (IMV) arco tangente 

LOG (POS) logaritmo neperiano 

EXP (X) antilogaritmo neperiano (ex) 
GOTO 


Realiza un salto al número de línea dado (o al resultado 
de la expresión en algunos casos) 


GOTO ([<número de línea>] [<expresión>]] 
GOTO 300 
GOTO INI + 40 (QL y Spectrum) 


IF/GOTO 


Si se cumple la condición ejecuta el GOTO si no, lo salta. 


IF <condición> GOTO ([<número de líneas>] 
[<expresión>]) 


IF M<1 GOTO 500 


IF/THEN 


Si la condición es cierta realiza el resto de las instruc- 
ciones de la línea si no, se las salta 
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IF <condición> THEN <instrucción 1> [: <instrucción 


5, ] 


IF M<Q THEN M=0 


IF/THEN/ELSE 
Si la condición es cierta realiza lo que venga hasta el 


ELSE y luego salta la instrucción de éste. Si no es cierta rea- 
liza lo del ELSE y continua. 


IF <condición> THEN <bloque instrucciones 1> 
[ELSE <bloque de instrucciones 2>] 


IF M<0 THEN M=0 ELSE M=2*M 


INPUT 


Asigna los valores introducidos por teclado a las varia- 
bles correspondientes. 


INPUT [:] ["<Mensaje>'(;,)] <variable 1> [,<variable 
2>..] 


INPUT A, Bf VECT(35) 
INPUT “JUNTO"X 


LEFTS 


Toma los n caracteres más a la izquierda de la cadena 


dada. 
LEFT$ (<cadena>, n) 


B$=LEFT$ (“JOSE",2) 
PRINT LEFT$ (B$1) 
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LEN 


Devuelve la longitud (número de caracteres) de la ca- 


dena 
LEN (<cadena>) 


L=LEN (“PEPE”) 
P=LEM (A$) 


LET 


Asigna a la variable situada a la izquierda del signo = 
el resultado de la expresión ubicada a la derecha. 


[LET] <variable>=<expresión> 


LET A=27*C 
B=584 
C£-"JUAN PEREZ” 


MIDS 


Toma n caracteres de la cadena, empezando por el nú- 


mero i-ésimo. 
MID$ (<cadena>, 1, n) 


MID$ (PEPE, 2,2) 
MID$ (M$ 8,15) 


PRINT 


Visualiza en la pantalla mensajes y valores de variables 
u operaciones, es decir, cualquier “expresión” 


PRINT <expresión 1> ([:] [,]) <expresión 2>.. 


PRINT “VOLUMEN ”;“DE B.Bl”; 
PRINT B$C¡ “VALOR” 
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READ 


Asigna a las variables dadas los valores extraídos de 
sentencias DATA. 


READ <variable 1> [<variable 2>.. ) 


READ DH$ PE(1,1) 


RESTORE 


Lleva el puntero de DATA activo al primer valor de la 
primera sentencia DATA, o de la que se señale (por su nú- 
mero de línea). 


RESTORE [(<número de línea> <expresión>)] 


RESTORE 
RESTORE 80 
RESTORE 1+8 


RIGHTS 


Toma los n caracteres más a la derecha de la cadena 
dada. 


B$=RIGHT$ (“SAN PEDRO"5) 
RIGHT$ (C$3) 
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INDICE GENERAL 


Dentro y fuera del ordenador 

Todo lo que debemos saber para poder comprender 
en qué consisten y cómo funcionan los ordenadores. 
Diccionario de términos informáticos 

Una perfecta guía en ese «maremagnum» de palabras y 
frases ininteligibles que se usan en Informática. 

Cómo elegir un ordenador... que se ajuste a nuestras 
necesidades 

Las características y detalles en los que deberemos 
centrar nuestra atención a la hora de elegir un 
ordenador. 

Cuidados del ordenador... cosas que debemos hacer o 
evitar 

Esos consejos que le evitarán problemas con su 
equipo, permitiéndole obtener el máximo provecho. 

¡Y llegó el BASIC! (1) 

Un claro y sencillo acercamiento a los principios de 
este popular lenguaje. 

Dimensión MSX 

El primer BASIC estándar que ha conseguido difundirse 
de verdad no es sólo un lenguaje; hay bastante más. 
¡Y llegó el BASIC! (II) 

Instrucciones y comandos que quedaron por explicar 
en el la parte 1 

Introducción al Pascal 

Una buena manera de adentrarse en la programación 
estructurada, ¡la nueva ola de la Informática! 
Programando como es debido... algoritmos y otros 
elementos necesarios. 
Ideas para mejorar la funcionalidad y desarrollo de sus 
programas, 

Sistemas operativos y software de base 

Qué son, para qué sirven. Unos desconocidos muy 
importantes. 

Sistema operativo CP/M 

Uno de los sistemas operativos para microprocesadores 
de 8 bits de mayor difusión en el mercado. 

MS-DOS: el estándar de IBM 

Sistema operativo para el microprocesador de 16 bits 
8088, adoptado por el IBM-PC, 

Paquetes de aplicaciones. Software “pret a porter” 
Características y peculiaridades de los más importantes 
paquetes de aplicaciones. 

VisiCalc: una buena hoja de cálculo 

Interioridades y manejo de una de las hojas de cálculo 
más usadas. 


15 Dibujar con el ordenador 
Profundizando en una de las facetas útiles y divertidas 
que nos ofrecen los ordenadores. 

16 Tratamiento de textos... para escribir con el ordenador 
Cómo convertir su ordenador en una máquina de 
escribir con memoria y todo tipo de posibilidades. 

17 Diseño de juegos 
Particularidades características de esta aplicación de 
los ordenadores. 

18 LOGO: la tortuga inteligente 
Un lenguaje conocido por su «cursor gráfico», la tortuga, 
y sus aplicaciones pedagógicas al alcance de su mano. 

19 BASIC y tratamiento de imágenes ; 
Todo lo que en ¡Y llegó el BASIC! no se pudo ver sobre 
las imágenes y gráficos en el BASIC. 

20 Bancos de datos (1) 

: Peculiaridades de una de las aplicaciones de los 
ordenadores más interesantes, y que más dinero 
mueven. 

21 Bancos de datos (II) 

Profundizando en sus características. 

22 Paquetes integrados: Lotus 1-2-3 y Simphony 
Estudio de dos de los paquetes integrados (Hoja de 
cálculo + base de datos +..) más conocidos. 

23 dBASE Il y dBASE II 
Cómo aprovechar las dos versiones más recientes de 
esta importante base de datos. 

24 Los ordenadores uno a uno 
Un amplio y completo estudio comparativo. 

25 Cálculo numérico en BASIC 
Una aplicación especializada a su disposición. 

26 Multiplan 
Cómo hacer uso de este moderno paquete de 
aplicaciones. 

27 FORTRAN y COBOL 
Dos lenguajes muy especializados y distintos. 

28 FORTH: anatomía de un lenguaje inteligente 
Principales características de un lenguaje moderno, 
flexible y de amplio uso, en la robótica. 

29 Cómo realizar nuestro propio banco de datos 
Conocimientos necesarios para poder fabricar un 
banco de datos a nuestro gusto y medida, 

30 Los paquetes integrados uno a uno 
Todos los que usted puede encontrar en el mercado. 

NOTA: Ingelek, S. A. se reserva el derecho de modificar, sin 

previo aviso, el orden, título o contenido de cualquier volu- 
men de la colección. 


UIZAS el rasgo más característico de un 
ordenador personal sea el carácter inme- 
diato de su utilización. Esto no significa, 
como muchas veces se piensa, que su ac- 
ceso sea simple, sino que permanece 
siempre a nuestra disposición, atento a 
nuestras instrucciones. Un buen ordena- 
dor personal debe ser “interactivo”, es 
decir, debe invitar al diálogo. Para ello tendrá que dis- 
poner de un lenguaje que permita este coloquio; el más 
sencillo y difundido es, sin duda, el BASIC. 

La simplicidad de sus reglas y el carácter interpre- 
tativo del lenguaje BASIC hacen que cada instrucción o 
grupo de instrucciones pueda utilizarse y comprobarse 
de inmediato. 

Después de los anteriores tomos de la colección 
creemos que es el momento adecuado para dar, de ma- 
nera optimista y sin temores, nuestros primeros pasos en 
BASIC. 

Insistimos una vez más en que NO es preciso que to- 
dos lleguemos a ser programadores expertos, pues hay 
una ingente cantidad de software disponible y la tarea 
de programar exige bastante tiempo y paciencia. Sin em- 
bargo, una base mínima es siempre útil y nos servirá, al 
menos, para comprender mejor el funcionamiento de los 
programas y sacar mayor rendimiento de estos y del or- 
denador. 


375 pts. 


